返回
首页 > 数码科技

Word的字数统计问题 word 是如何统计字数的

时间: 2023-01-21

对于需要和大量文字打交道的人,在使用Word的字数统计功能时,如果你的文档中有比较特殊的内容,例如文本框,那么有一个问题一定需要注意,那就是,在2007版之前的Word中,文字统计功能并不统计文本框内文字的字数。cpcoffice教程网

这是个Word 2007中的文本框范例截图 cpcoffice教程网

这个问题我一直都没有意识到,主要因为我一直使用最新版本的Word,而没有发现这个问题。最近处理的一本书稿,无论怎样计算,我这里统计的字数和出版社最终统计的字数都有所差别,而且竟然差了好几万字。这就比较奇怪了,后来经过仔细检查才发现,就是文本框的问题。出版社使用的是Word 2003,统计字数并不包含文本框内的文字,而我这个书稿里有大量内容,为了保持版面的美观,都放在了文本框中,这也就导致统计字数有很大偏差。cpcoffice教程网

因此如果因为某些原因必须使用老版本Word,可以考虑使用宏的方式实现,做法可参考这里。cpcoffice教程网

作为存档,这里将宏的内容一起照原样贴出来,感谢原作者的工作成果:cpcoffice教程网

‘统计全部字数的代码使用了网友Lieven Lannoo <lieven.lannoo@nci.be>提供的解决方案 cpcoffice教程网
Dim oStory As Object, WordCount, WordChar As Long cpcoffice教程网
Dim dhk As Dialog ‘定义对话框变量 cpcoffice教程网
Dim MainNumWords As Long ‘ 文档主体的字数 cpcoffice教程网
Dim MainNumChars As Long ‘ 文档主体的字符数 cpcoffice教程网
Application.ScreenUpdating = False ‘关闭屏幕刷新提高统计速度 cpcoffice教程网
For Each oStory In ActiveDocument.StoryRanges ‘遍历文档字符 cpcoffice教程网
WordCount = WordCount + oStory.ComputeStatistics(wdStatisticWords) ‘文档全部字数(含文本框中的) cpcoffice教程网
WordChar = WordChar + oStory.ComputeStatistics(wdStatisticCharacters) ‘文档全部字符数(含文本框中的) cpcoffice教程网
Do While Not (oStory.NextStoryRange Is Nothing) ‘同一组合内的下一个对象不空则继续统计 cpcoffice教程网
Set oStory = oStory.NextStoryRange cpcoffice教程网
WordCount = WordCount + oStory.ComputeStatistics(wdStatisticWords) ‘累加上同一组合内字数 cpcoffice教程网
WordChar = WordChar + oStory.ComputeStatistics(wdStatisticCharacters) ‘累加上同一组合内字符数 cpcoffice教程网
Loop cpcoffice教程网
Next oStory cpcoffice教程网
Selection.HomeKey Unit:=wdStory ‘将所选内容移至文档开头 cpcoffice教程网
Set dhk = Dialogs(wdDialogToolsWordCount) ‘将dhk设置为"字数统计"对话框 cpcoffice教程网
dhk.Update cpcoffice教程网
dhk.Execute cpcoffice教程网
MainNumWords = dhk.Words ‘获得文档主体的字数 cpcoffice教程网
MainNumChars = dhk.Characters ‘获得文档主体的字符数 cpcoffice教程网
Application.ScreenUpdating = True ‘统计完毕恢复屏幕刷新 cpcoffice教程网
‘显示统计结果 cpcoffice教程网
MsgBox "使用当中遇到任何问题,请随时与我联系。" & vbCr & vbCr _ cpcoffice教程网
& "电气工程师兼日语翻译――真庸" & vbCr & vbCr _ cpcoffice教程网
& "电子信箱:ruiteng2005@126.com" & vbCr & vbCr _ cpcoffice教程网
& "QQ:383290039" & vbCr & vbCr _ cpcoffice教程网
& "MSN:ruiteng2005@hotmail.com" & vbCr & vbCr _ cpcoffice教程网
& "电话:13312029710   或者 13389935832" & vbCr & vbCr _ cpcoffice教程网
& "" & vbCr & vbCr _ cpcoffice教程网
& "****包括文档主体/各种框架内的字数/字符数统计信息****" & vbCr & vbCr _ cpcoffice教程网
& "整个文档字数总计  :" & WordCount & vbCr _ cpcoffice教程网
& "整个文档字符数总计:" & WordChar & vbCr & vbCr _ cpcoffice教程网
& "    其中1、有关文本框的统计信息" & vbCr _ cpcoffice教程网
& "           文本框数量        :" & Str(ActiveDocument.Shapes.Count) & vbCr _ cpcoffice教程网
& "           文本框字数合计    :" & WordCount – MainNumWords & vbCr _ cpcoffice教程网
& "           文本框字符数合计  :" & WordChar – MainNumChars & vbCr & vbCr _ cpcoffice教程网
& "        2、有关文档主体的统计信息" & vbCr _ cpcoffice教程网
& "(即WORD自带的“字数统计”功能统计的结果)" & vbCr _ cpcoffice教程网
& "           文档主体字数合计              :" & MainNumWords & vbCr _ cpcoffice教程网
& "           文档主体字符数合计(不计空格):" & MainNumChars
cpcoffice教程网

不得不再次感叹,MS Office的功能实在是太强大了,虽然其中绝大部分功能,大部分人可能根本用不到,而且可能压根不知道这些功能的存在,不过,如果确实需要的时候,还真是挺方便的。cpcoffice教程网

猜你喜欢

版权所有 Copyright©2023 餐饮美食网 版权所有

粤ICP备15109582号

联系邮箱:187348839@qq.com