Foxtable(狐表)用户栏目专家坐堂 → [求助]打印关联子表问题


  共有3179人关注过本帖树形打印复制链接

主题:[求助]打印关联子表问题

帅哥哟,离线,有人找我吗?
zwmdlj
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:婴狐 帖子:7 积分:123 威望:0 精华:0 注册:2018/10/17 11:09:00
[求助]打印关联子表问题  发帖心情 Post By:2018/10/19 13:29:00 [只看该作者]

打印关联子表时,在word中插入了关联子表,但在word模板预览时,只能显示在狐表中点中的那个单元格所在行的内容,想请教如何把狐表中表格中的全部内容打印到word中

 回到顶部
帅哥哟,离线,有人找我吗?
zwmdlj
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:婴狐 帖子:7 积分:123 威望:0 精华:0 注册:2018/10/17 11:09:00
  发帖心情 Post By:2018/10/19 13:30:00 [只看该作者]


此主题相关图片如下:狐表内容.png
按此在新窗口浏览图片

此主题相关图片如下:word模板插入关联子表预览效果.png
按此在新窗口浏览图片
打印关联子表时,在word中插入了关联子表,但在word模板预览时,只能显示在狐表中点中的那个单元格所在行的内容,想请教如何把狐表中表格中的全部内容打印到word中
此主题相关图片如下:word模板插入关联子表.png
按此在新窗口浏览图片

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110813 积分:564003 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2018/10/19 14:25:00 [只看该作者]

子表选中几行就打印几行

 回到顶部
帅哥哟,离线,有人找我吗?
zwmdlj
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:婴狐 帖子:7 积分:123 威望:0 精华:0 注册:2018/10/17 11:09:00
  发帖心情 Post By:2018/10/19 15:29:00 [只看该作者]

以下是引用有点蓝在2018/10/19 14:25:00的发言:
子表选中几行就打印几行
按照你说的选了,但选几行就打印几行,但打印是分几个表出来的,选3行,就打印成三个表了


 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110813 积分:564003 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2018/10/19 15:31:00 [只看该作者]

不可能的,除非不是子表,也没有关联。具体上传实例说明

 回到顶部
帅哥哟,离线,有人找我吗?
zwmdlj
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:婴狐 帖子:7 积分:123 威望:0 精华:0 注册:2018/10/17 11:09:00
  发帖心情 Post By:2018/10/19 17:09:00 [只看该作者]

我重新做了一个,还是这种情况,不知道问题出在哪,请帮忙解决,谢谢!
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:通讯录111.zip


 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110813 积分:564003 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2018/10/19 17:35:00 [只看该作者]

您应该理解错了。父表一页只能显示一行,然后子表只能显示父表选中的那一行对应的子表记录。

这种仅仅为了显示2个表的数据,其实和关联表、父子表这种其实没有什么关系了。需要通过代码输出,例如

Dim tm As String  = ProjectPath & "Attachments\通讯录.doc" '指定模板文件
Dim fl As String = ProjectPath & "Reports\通讯录.doc" '指定目标文件
Dim wrt As New WordReport(Tables("成本控制中心"),tm,fl) '定义一个WordReport
Dim sum As Integer
For i As Integer = 0 To Tables("成本控制中心").rows.count - 1
    Dim r As Row = Tables("成本控制中心").rows(i)
    wrt.ReplaceOne("[@成本控制中心,部门," &  (i+1) & "]",r("部门"))
    wrt.ReplaceOne("[@成本控制中心,姓名," &  (i+1) & "]",r("姓名"))
Next
wrt.BuildOne(Tables("成本控制中心").rows(0))
wrt.Show() '显示报表

 回到顶部
帅哥哟,离线,有人找我吗?
zwmdlj
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:婴狐 帖子:7 积分:123 威望:0 精华:0 注册:2018/10/17 11:09:00
  发帖心情 Post By:2018/10/22 11:46:00 [只看该作者]

谢谢老师的帮助,用您提供的代码果然解决了问题,但还有个小问题想请教,
图片点击可在新窗口打开查看此主题相关图片如下:word模板输出效果.png
图片点击可在新窗口打开查看,word模板中行数多余行如何显示成无内容的空白行?


 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2018/10/22 11:56:00 [只看该作者]

代码改成

 

Dim tm As String  = ProjectPath & "Attachments\通讯录.doc" '指定模板文件
Dim fl As String = ProjectPath & "Reports\通讯录.doc" '指定目标文件
Dim wrt As New WordReport(Tables("成本控制中心"),tm,fl) '定义一个WordReport
Dim sum As Integer
For i As Integer = 0 To Tables("成本控制中心").rows.count - 1
    Dim r As Row = Tables("成本控制中心").rows(i)
    wrt.ReplaceOne("[@成本控制中心,部门," &  (i+1) & "]",r("部门"))
    wrt.ReplaceOne("[@成本控制中心,姓名," &  (i+1) & "]",r("姓名"))
Next
For i As Integer = Tables("成本控制中心").rows.count to 4
    wrt.ReplaceOne("[@成本控制中心,部门," &  (i) & "]", "")
    wrt.ReplaceOne("[@成本控制中心,姓名," &  (i) & "]", "")
Next
wrt.BuildOne(Tables("成本控制中心").rows(0))
wrt.Show() '显示报表

 回到顶部
帅哥哟,离线,有人找我吗?
zwmdlj
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:婴狐 帖子:7 积分:123 威望:0 精华:0 注册:2018/10/17 11:09:00
  发帖心情 Post By:2018/10/22 18:52:00 [只看该作者]

谢谢版主赐教!

 回到顶部