Private Sub Command1_Click()
Dim objFSO
Set objFSO = CreateObject("Scripting.FileSystemObject")
If Not objFSO.FileExists("c:\a.txt") Then
MsgBox "a.txt is not exist!"
Exit Sub
End IfConst ForReading = 1
Set txtFile = objFSO.OpenTextFile("c:\a.txt", ForReading)
strLine = txtFile.ReadlineDim tmp
tmp = Split(strLine, "@")
'MsgBox tmp(0)
'MsgBox tmp(1)
'MsgBox tmp(2)Dim docApp
Set docApp = CreateObject("Word.Application")
docApp.Visible = True
Set qq = docApp.Documents.Open("C:\abc\dong\qq.doc")
Set doc1 = docApp.Documents.Open(tmp(2))
doc1.Activate
docApp.Selection.WholeStory
docApp.Selection.Copy
qq.Activate
docApp.Selection.WholeStory
docApp.Selection.PastedocApp.Selection.Find.ClearFormatting
With docApp.Selection.Find
.Text = "姓名"
.Replacement.Text = ""
.Forward = True
.Wrap = 1
.Format = False
.MatchCase = False
.MatchWholeWord = False
.MatchByte = False
.MatchAllWordForms = False
.MatchSoundsLike = False
.MatchWildcards = False
.MatchFuzzy = True
End With
docApp.Selection.Find.Execute
docApp.Selection.TypeText tmp(0)docApp.Selection.Find.ClearFormatting
With docApp.Selection.Find
.Text = "地点"
.Replacement.Text = ""
.Forward = True
.Wrap = 1
.Format = False
.MatchCase = False
.MatchWholeWord = False
.MatchByte = False
.MatchAllWordForms = False
.MatchSoundsLike = False
.MatchWildcards = False
.MatchFuzzy = True
End With
docApp.Selection.Find.Execute
docApp.Selection.TypeText tmp(1)qq.Save
qq.Close
doc1.CloseSet qq = Nothing
Set doc1 = Nothing
docApp.Quit
Set docApp = Nothing
Set objFSO = NothingEnd Sub以上代码实现的功能是:
在C盘有个文件,例如c:\a.txt文件,这个文件有这样的数据:小黄@上海@C:\abc\dong\姓名表.doc;还有另外一个C:\abc\dong\qq.doc,这个qq.doc是个没有数据的word,也就是空白的word。
在这个姓名表.doc里有二个中括号,中括号里分别是姓名和地点,例如:[姓名] [地点]
a.txt里的小黄和上海二个数据读入到姓名表.doc里,读完后就自动把姓名表.doc的全部内容移到qq.doc里,移完后姓名表.doc这个文件就恢复到读数据之前以被下一次重复使用,
说明:1、c:\a.txt文件里的数据是随时可以修改的,例如:可以改成小将@北京@C:\abc\dong\报名.doc。但上面的只有三个数据分别用@标记分开,他们的含义是姓名、地点、所要调用的word路径,但数据长度不一定相等的。
2、C:\abc\dong\目录下的word模板有很多种。例如还有报名.doc等等。
我现在的问题1、就是a.txt是数据是小黄@上海@C:\abc\dong\姓名表.doc 在姓名表.doc里如果就要[地点]那怎么解决?
2、假如a.txt的数据增加了变成小黄@上海@2004-05-09@C:\abc\dong\报名表.doc 这时报名表.doc要的数据是[姓名] [地点] [那年] [那月] [那日] 也就是小黄替换[姓名];上海替换[地点];2004替换[那年];05替换[那月];09替换[那日];
Dim objFSO
Set objFSO = CreateObject("Scripting.FileSystemObject")
If Not objFSO.FileExists("c:\a.txt") Then
MsgBox "a.txt is not exist!"
Exit Sub
End IfConst ForReading = 1
Set txtFile = objFSO.OpenTextFile("c:\a.txt", ForReading)
strLine = txtFile.ReadlineDim tmp
tmp = Split(strLine, "@")
'MsgBox tmp(0)
'MsgBox tmp(1)
'MsgBox tmp(2)Dim docApp
Set docApp = CreateObject("Word.Application")
docApp.Visible = True
Set qq = docApp.Documents.Open("C:\abc\dong\qq.doc")
Set doc1 = docApp.Documents.Open(tmp(2))
doc1.Activate
docApp.Selection.WholeStory
docApp.Selection.Copy
qq.Activate
docApp.Selection.WholeStory
docApp.Selection.PastedocApp.Selection.Find.ClearFormatting
With docApp.Selection.Find
.Text = "姓名"
.Replacement.Text = ""
.Forward = True
.Wrap = 1
.Format = False
.MatchCase = False
.MatchWholeWord = False
.MatchByte = False
.MatchAllWordForms = False
.MatchSoundsLike = False
.MatchWildcards = False
.MatchFuzzy = True
End With
docApp.Selection.Find.Execute
docApp.Selection.TypeText tmp(0)docApp.Selection.Find.ClearFormatting
With docApp.Selection.Find
.Text = "地点"
.Replacement.Text = ""
.Forward = True
.Wrap = 1
.Format = False
.MatchCase = False
.MatchWholeWord = False
.MatchByte = False
.MatchAllWordForms = False
.MatchSoundsLike = False
.MatchWildcards = False
.MatchFuzzy = True
End With
docApp.Selection.Find.Execute
docApp.Selection.TypeText tmp(1)qq.Save
qq.Close
doc1.CloseSet qq = Nothing
Set doc1 = Nothing
docApp.Quit
Set docApp = Nothing
Set objFSO = NothingEnd Sub以上代码实现的功能是:
在C盘有个文件,例如c:\a.txt文件,这个文件有这样的数据:小黄@上海@C:\abc\dong\姓名表.doc;还有另外一个C:\abc\dong\qq.doc,这个qq.doc是个没有数据的word,也就是空白的word。
在这个姓名表.doc里有二个中括号,中括号里分别是姓名和地点,例如:[姓名] [地点]
a.txt里的小黄和上海二个数据读入到姓名表.doc里,读完后就自动把姓名表.doc的全部内容移到qq.doc里,移完后姓名表.doc这个文件就恢复到读数据之前以被下一次重复使用,
说明:1、c:\a.txt文件里的数据是随时可以修改的,例如:可以改成小将@北京@C:\abc\dong\报名.doc。但上面的只有三个数据分别用@标记分开,他们的含义是姓名、地点、所要调用的word路径,但数据长度不一定相等的。
2、C:\abc\dong\目录下的word模板有很多种。例如还有报名.doc等等。
我现在的问题1、就是a.txt是数据是小黄@上海@C:\abc\dong\姓名表.doc 在姓名表.doc里如果就要[地点]那怎么解决?
2、假如a.txt的数据增加了变成小黄@上海@2004-05-09@C:\abc\dong\报名表.doc 这时报名表.doc要的数据是[姓名] [地点] [那年] [那月] [那日] 也就是小黄替换[姓名];上海替换[地点];2004替换[那年];05替换[那月];09替换[那日];
解决方案 »
- 如何获取datagrid的字段名
- 如何将多个相同结构的excel导入到SqlServer
- 怎样在excel表里追加(续写)内容
- 关于向access中添加数据的问题,分不多了,请各位好心人帮帮忙,急
- 能不能将一个excel文件里面某个sheet的内容,显示在一个窗体上?
- 哪里有0-9的数字发音下载?
- 如何制作收银小票打印(水晶报表)多谢各位了!在线等待
- 求VB6.0的高手帮忙
- 怎么获得2000下登陆用户的用户名和密码?(用VB)
- ADO与datagrid结合使用时,即使数据库的某个字段的缺省值是0,但当写完一行把焦点转到另一行时,缺省字段的值仍然为Null,不知为何
- 如何从A机查看B机的屏幕??请提供源码
- 各位大虾,是去给日本作外包的企业好呢?还是去金蝶分公司好呢?
只要地点:把下面这段删除:
docApp.Selection.Find.ClearFormatting
With docApp.Selection.Find
.Text = "姓名"
.Replacement.Text = ""
......
End With
docApp.Selection.Find.Execute
docApp.Selection.TypeText tmp(0)2
1. 在 tmp = Split(strLine, "@") 之前家一句
strLine = Replace(strline,"-","@")2 增加下列代码:
docApp.Selection.Find.ClearFormatting
With docApp.Selection.Find
.Text = "那年"
.Replacement.Text = ""
.Forward = True
.Wrap = 1
.Format = False
.MatchCase = False
.MatchWholeWord = False
.MatchByte = False
.MatchAllWordForms = False
.MatchSoundsLike = False
.MatchWildcards = False
.MatchFuzzy = True
End With
docApp.Selection.Find.Execute
docApp.Selection.TypeText tmp(2)docApp.Selection.Find.ClearFormatting
With docApp.Selection.Find
.Text = "那月"
.Replacement.Text = ""
.Forward = True
.Wrap = 1
.Format = False
.MatchCase = False
.MatchWholeWord = False
.MatchByte = False
.MatchAllWordForms = False
.MatchSoundsLike = False
.MatchWildcards = False
.MatchFuzzy = True
End With
docApp.Selection.Find.Execute
docApp.Selection.TypeText tmp(3)docApp.Selection.Find.ClearFormatting
With docApp.Selection.Find
.Text = "那日"
.Replacement.Text = ""
.Forward = True
.Wrap = 1
.Format = False
.MatchCase = False
.MatchWholeWord = False
.MatchByte = False
.MatchAllWordForms = False
.MatchSoundsLike = False
.MatchWildcards = False
.MatchFuzzy = True
End With
docApp.Selection.Find.Execute
docApp.Selection.TypeText tmp(4)>谢谢你的回答。其实我的第一个问题不能象你说讲的删除些代码就好了,因为c:\a.txt文件里的数据是随时可以修改的,例如:可以改成小将@北京@C:\abc\dong\报名.doc。上面的三个数据分别用@标记分开,他们的含义和顺序是固定的分别是姓名、地点、所要调用的word路径。也就是说有些doc文件是要[姓名] [地点] 二个数据的;有些要一个的。能否做到doc文件里要哪个数据就读入那个数据,例如报名表.doc要[姓名] [地点] 二个数据,那就要把a.txt里的小将和北京二个数据读进去。你没有想通。
tmp = Split(strLine, "@")
语句已经把你的字符串切分过程了数组,有 N 个 @ 就有 N+1 个元素。你只要挑你需要的就行了。只要将 [姓名] [地点] 等对象与数据顺序的下标一一对应即可。因为你的代码中是搜索[姓名] [地点]等关键字的,然后填入相应下标的数据元素。所以只要在需要数据少的地方删除你多余的代码即可。