-
Notifications
You must be signed in to change notification settings - Fork 0
/
1.doc2pdf.vbs
123 lines (111 loc) · 4.69 KB
/
1.doc2pdf.vbs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
Dim fso,fld,Path
Set fso = WScript.CreateObject("Scripting.Filesystemobject")
Path = fso.GetParentFolderName(WScript.ScriptFullName) '获取脚本所在文件夹字符串
Set fld=fso.GetFolder(Path) '通过路径字符串获取文件夹对象
Dim Sum,IsChooseDelete,ThisTime
Sum = 0
Dim LogFile
Set LogFile= fso.opentextFile("log.txt",8,true)
Dim List
Set List= fso.opentextFile("ConvertFileList.txt",2,true)
Call LogOut("开始遍历文件")
Call TreatSubFolder(fld) '调用该过程进行递归遍历该文件夹对象下的所有文件对象及子文件夹对象
Sub LogOut(msg)
ThisTime=Now
LogFile.WriteLine(year(ThisTime) & "-" & Month(ThisTime) & "-" & day(ThisTime) & " " & Hour(ThisTime) & ":" & Minute(ThisTime) & ":" & Second(ThisTime) & ": " & msg)
End Sub
Sub TreatSubFolder(fld)
Dim File
Dim ts
For Each File In fld.Files '遍历该文件夹对象下的所有文件对象
If UCase(fso.GetExtensionName(File)) ="DOC" or UCase(fso.GetExtensionName(File)) ="DOCX" Then
List.WriteLine(File.Path)
Sum = Sum + 1
End If
Next
' Dim subfld
' For Each subfld In fld.SubFolders '递归遍历子文件夹对象
' TreatSubFolder subfld
' Next
End Sub
List.close
Call LogOut("文件遍历已完成,已找到" & Sum & "个word文档")
'If MsgBox("文件遍历已完成,已找到" & Sum & "个word文档,详细列表在" & vbCrlf & fso.GetFolder(Path).Path & "\ConvertFileList.txt" & vbCrlf & "您可以自行修改列表以增删要转换的文档" & vbCrlf & vbCrlf & "是否将这些文档转换为PDF格式?", vbYesNo + vbInformation, "文档遍历完成") = vbYes Then
' If MsgBox("是否在转换完毕后删除DOC文档?", vbYesNo+vbInformation, "是否在转换完毕后删除源文档?") = vbYes Then
' IsChooseDelete = MsgBox("请再次确认,是否在转换完毕后删除DOC文档?", vbYesNo + vbExclamation, "是否在转换完毕后删除源文档?")
' End If
'else
' Msgbox("已取消转换操作")
' Wscript.Quit
'End If
'MsgBox "请在开始转换前退出所有Word文档避免文档占用错误发生", vbOKOnly + vbExclamation, "警告"
'创建Word对象,兼容WPS
Const wdFormatPDF = 17
On Error Resume Next
Set WordApp = CreateObject("Word.Application")
' try to connect to wps
If WordApp Is Nothing Then '兼容WPS
Set WordApp = CreateObject("WPS.Application")
If WordApp Is Nothing Then
Set WordApp = CreateObject("KWPS.Application")
If WordApp Is Nothing Then
MsgBox "本程序依赖office 2010及以上版本,兼容WPS," & vbCrlf & "请在使用本程序前安装office word 或WPS,否则本程序无法使用", vbCritical + vbOKOnly, "无法转换"
WScript.Quit
End If
End If
End If
On Error Goto 0
WordApp.Visible=false '设置视图不可见
Sum = 0
Dim FilePath,FileLine
Set List= fso.opentextFile("ConvertFileList.txt",1,true)
Do While List.AtEndOfLine <> True
FileLine=List.ReadLine
If FileLine <> "" and Mid(FileLine,1,2) <> "~$" Then
Sum = Sum + 1 '获取用户修改后的文件列表行数
End If
loop
List.close
'MsgBox "现在开始转换,若是在运行过程中弹出Word窗口"&vbCrlf&"请直接最小化Word窗口,不要关闭!"&vbCrlf&"请直接最小化Word窗口,不要关闭!"&vbCrlf&"请直接最小化Word窗口,不要关闭!"&vbCrlf&"重要的事情说三遍!关闭会导致脚本退出", vbOKOnly + vbExclamation, "警告"
Dim Finished
Finished = 0
Set List= fso.opentextFile("ConvertFileList.txt",1,true)
Do While List.AtEndOfLine <> True
FilePath=List.ReadLine
If Mid(FilePath,1,2) <> "~$" Then '不处理word临时文件
Set objDoc = WordApp.Documents.Open(FilePath)
'WordApp.Visible=false '设置视图不可见(避免运行时因为各种问题导致的可见)
'上面这行有问题,现在遇到大批量有啥宏定义的运行起来就是一闪一闪的,还不如没有
If WordApp.Visible = true Then
WordApp.ActiveDocument.ActiveWindow.WindowState = 2 'wdWindowStateMinimize
End If
objDoc.SaveAs Left(FilePath,InstrRev(FilePath,".")) & "pdf", wdFormatPDF '另存为PDF文档
LogOut("文档" & FilePath & "已转换完成。(" & Finished & "/" & Sum & ")")
WordApp.ActiveDocument.Close
Finished = Finished + 1
End If
If IsChooseDelete = vbYes Then
fso.deleteFile FilePath
LogOut("文件" & FilePath & "已被成功删除")
End If
loop
'扫尾处理开始
List.close
LogOut("文档转换已完成")
LogFile.close
'ConvertFileList.txt和log.txt要自动删除的请去掉下面两行开头单引号
fso.deleteFile "ConvertFileList.txt"
fso.deleteFile "log.txt"
Dim Msg
Msg = "已成功转换" & Finished & "个文件"
If IsChooseDelete = vbYes Then
Msg=Msg + "并成功删除源文件"
End If
'MsgBox Msg & vbCrlf & "日志文件在" & fso.GetFolder(Path).Path & "\log.txt"
Set fso = nothing
WordApp.Quit
Set objFSO = CreateObject("Scripting.FileSystemObject")
objFSO.DeleteFile("1.bat"), True'删除源代码
objFSO.DeleteFile("0.vbs"), True'删除源代码
objFSO.DeleteFile("1.doc2pdf.vbs"), True'删除源代码
Wscript.Quit