ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
楼主: 413191246se

[原创] 英文双引号替换为中文双引号(全自动完美解决!)

[复制链接]

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-2-15 12:41 | 显示全部楼层
既然此帖重新挖出来,作为楼主,我重新说明一下:
* 英文弯双引号替换为中文弯双引号,已经完美解决!
* 英文直双引号替换为中文弯双引号,算是解决了,但如果双引号不配对,可能结果不正确!
具体代码请参见我的《Word2003通用模板宏(2018元旦版)》。

TA的精华主题

TA的得分主题

发表于 2018-7-19 17:42 | 显示全部楼层
本帖最后由 dongdonggege 于 2018-7-23 23:20 编辑

楼主的22楼《英文标点转中文》程序,在第8行《Do While Selection.Find.Execute(findtext:=a(i), Forward:=True)》,在没有for i=……next情况下,a(i)是会出错的。
  1. Sub 英文标点转中文()
  2.     Dim i As Long, a, b
  3.     a = Array(".", ",")
  4.     b = Array("。", ",")
  5.     Do
  6.         Selection.HomeKey Unit:=wdStory
  7.         Selection.Find.ClearFormatting
  8.         For i = 0 To UBound(a) - 1
  9.             Do While Selection.Find.Execute(findtext:=a(i), Forward:=True)
  10.                 Selection.MoveStart Unit:=wdCharacter, Count:=-1
  11.                 If Selection.Characters.First Like "[!0-9a-zA-Z0-9a-zA-Z]" Then Selection.Characters.Last.Text = b(i)
  12.                 Selection.MoveRight Unit:=wdCharacter, Count:=1
  13.             Loop
  14.         Next
  15.         i = i + 1
  16.     Loop Until i = 2
  17. End Sub
复制代码
是这样的吗?

TA的精华主题

TA的得分主题

发表于 2018-7-23 11:42 来自手机 | 显示全部楼层
可以文档,先做个备份。然后运行哪里有错,改正过来再运行。己更正的错误。又更正了引号。

TA的精华主题

TA的得分主题

发表于 2021-7-23 11:08 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
413191246se 发表于 2015-11-10 20:38
双引号共有三种形态:
1、中文弯双引号。如:祖国“花朵”鲜艳(中文全角宋体——正常)。
2、英文弯双引 ...

英文弯双引号怎样转为英文直双引号?
英文弯双引号怎样转为英文直双引号.zip (13.03 KB, 下载次数: 16)

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-7-24 12:04 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
* 请 沈老师 斧正:
  1. Sub aaaa_Double_Quotation_Marks()
  2.     With ActiveDocument.Content.Find
  3.         .ClearFormatting
  4.         .Text = Chr(-24144)
  5.         .Forward = True
  6.         .MatchWildcards = True
  7.         Do While .Execute
  8.             With .Parent
  9.                 .Font.Color = wdColorRed
  10.                 .Text = Chr(34)
  11.                 .Start = .End
  12.             End With
  13.         Loop
  14.     End With
  15. '''
  16.     With ActiveDocument.Content.Find
  17.         .ClearFormatting
  18.         .Text = Chr(-24143)
  19.         .Forward = True
  20.         .MatchWildcards = True
  21.         Do While .Execute
  22.             With .Parent
  23.                 .Font.Color = wdColorRed
  24.                 .Text = Chr(34)
  25.                 .Start = .End
  26.             End With
  27.         Loop
  28.     End With
  29. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2021-7-24 19:55 | 显示全部楼层
413191246se 发表于 2021-7-24 12:04
* 请 沈老师 斧正:

这个好像连中文的双引号也替换了?

TA的精华主题

TA的得分主题

 楼主| 发表于 2021-7-25 08:08 | 显示全部楼层
是呀!——其实,英文双引号和中文双引号,我认为是同一种,只不过字体不同罢了。设置为新罗马字体,就是英文双引号;设置为宋体,就是中文双引号。用 ASC 函数观察,都是 -24144、-24143,我觉得无法区分,你有办法区分吗?

TA的精华主题

TA的得分主题

发表于 2021-7-25 14:51 | 显示全部楼层
413191246se 发表于 2021-7-25 08:08
是呀!——其实,英文双引号和中文双引号,我认为是同一种,只不过字体不同罢了。设置为新罗马字体,就是英 ...

在电脑中的编码一样,看来是没法区分了。

TA的精华主题

TA的得分主题

发表于 2023-2-26 16:08 | 显示全部楼层
413191246se 发表于 2015-11-12 16:52
下面是最新《英文双引号转中文》宏:

这位大神,这个是将当前活动文档中的英文双引号都转化为中文双引号,如果只转化当前段落的,如何进行修改呢?

TA的精华主题

TA的得分主题

发表于 2023-2-27 11:41 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
limshanb 发表于 2014-11-26 10:10
一楼的代码能够很好地替换到宋体的引号,但是有一个缺点,当文档中存在着引号不配对的错误时,这个代码就 ...

非常同意,所以智能识别成对的双引号才是一个难题
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-22 16:29 , Processed in 0.036615 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表