Access交流中心

北京 | 上海 | 天津 | 重庆 | 广州 | 深圳 | 珠海 | 汕头 | 佛山 | 中山 | 东莞 | 南京 | 苏州 | 无锡 | 常州 | 南通 | 扬州 | 徐州 | 杭州 | 温州 | 宁波 | 台州 | 福州 | 厦门 | 泉州 | 龙岩 | 合肥 | 芜湖 | 成都 | 遂宁 | 长沙 | 株洲 | 湘潭 | 武汉 | 南昌 | 济南 | 青岛 | 烟台 | 潍坊 | 淄博 | 济宁 | 太原 | 郑州 | 石家庄 | 保定 | 唐山 | 西安 | 大连 | 沈阳 | 长春 | 昆明 | 兰州 | 哈尔滨 | 佳木斯 | 南宁 | 桂林 | 海口 | 贵阳 | 西宁 | 乌鲁木齐 | 包头 |

求大神修改代码?

艹右小土  发表于:2014-01-02 13:19:47  
复制

我用以下代码向word模板中输入窗体控件中的值,打印报表,但是窗体控件中入出现空值时,导出的word报表中,后面的书签都成空项,举例说,如果学生信息!text111是空值的话,模板书签2以后的项全部为空,程序报错,求大神们帮助修改一下,控件中有空值时,继续后面的程序!!!谢谢

Private Sub 打印_Click()

Dim wordapp As New word.Application

Dim worddoc As word.Document
Dim str As String
str = CurrentProject.Path & "\模板.dotx"
Set worddoc = wordapp.Documents.Add(str, False)
wordapp.Visible = True
 With wordapp.Selection
  .GoTo what:=wdGoToBookmark, Name:="模板书签1"
     .TypeText Forms!学生信息!Text107
  .GoTo what:=wdGoToBookmark, Name:="模板书签2"
     .TypeText Forms!学生信息!Text111
  .GoTo what:=wdGoToBookmark, Name:="模板书签3"
     .TypeText Forms!学生信息!Text109
 End With

Set wordapp = Nothing   '释放变量
Set worddoc = Nothing
End Sub

 

Top
落尘_小新 发表于:2014-01-02 13:35:15

With wordapp.Selection

.GoTo what:=wdGoToBookmark, Name:="模板书签1"

    If Len(Nz(Forms!学生信息!Text107)) <> 0 Then .TypeText Forms!学生信息!Text107
    .GoTo what:=wdGoToBookmark, Name:="模板书签2"
        If Len(Nz(Forms!学生信息!Text111)) <>Then .TypeText Forms!学生信息!Text111
    .GoTo what:=wdGoToBookmark, Name:="模板书签3"
        If Len(Nz(Forms!学生信息!Text109)) <>Then .TypeText Forms!学生信息!Text109

End With

试试看行不行.



艹右小土 发表于:2014-01-02 15:20:44
谢谢小新,总是麻烦你!搞定了!

艹右小土 发表于:2014-01-02 15:22:03
这个应该对,文本、数字、日期等不同类型的控件都有效吧?

总记录:3篇  页次:1/1 9 1 :