【Excel】【VBA】英文双引号替换为中文双引号

一、代码

' 将当前工作表中的英文双引号替换为中文双引号
Sub ReplaceQuote()
    Dim regex As Object
    Set regex = CreateObject("VBScript.RegExp")
    
    ' 正则表达式模式,匹配被英文双引号包围的任何文本
    regex.Pattern = """(.*?)"""
    regex.Global = True ' 用于全局匹配
    regex.MultiLine = True ' 用于跨行匹配
    
    ' 遍历工作表中的每个单元格
    Dim ws As Worksheet
    Set ws = ActiveSheet
    Dim cell As Range
    For Each cell In ws.UsedRange
        ' 使用正则表达式进行替换
        cell.Value = regex.Replace(cell.Value, "“$1”")
    Next cell
    
    ' 清理
    Set regex = Nothing
End Sub

二、待优化点

  • EXCEL不支持富文本(即一个单元格中存在多种格式),因此当单元格中存在富文本时,运行上述程序后,产生替换的单元格的格式将发生变化。举个例子:某一单元格中存在英文双引号、且部分文本被加粗,则运行上述程序后,该单元格中的英文双引号将被替换成中文双引号、同时所有文本不再加粗。

三、VBA操作过程

图 1
图 2
图 3
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值