在VB.net中,用正则表达式方法清除干扰符号方法

==标题==

|---------------------------|
| 在VB.net中,用正则表达式方法清除干扰符号方法 |

==正文==

上一篇提到通常的word文档复制、粘贴的干扰符号有:chr(7)、chr(11)、chr(13)、chr(9)、chr(160)

在VBA中,提取word表格的文本时,通常有什么干扰符号,需要清除

今天来设计一个函数来清洗它们

一、在VB.NET中使用正则表达式清除Word表格文本中的干扰符号(如Chr(7)Chr(13)Chr(11)),可通过以下方法实现:

apache 复制代码
Imports System.Text.RegularExpressionsFunction CleanTableText(inputText As String) As String    Dim pattern As String = "[\x07\x0B\x0D]"  ' 匹配Chr(7), Chr(11), Chr(13)    Return Regex.Replace(inputText, pattern, String.Empty)End Function

代码说明

  1. 正则模式[\x07\x0B\x0D] 使用十六进制表示法匹配:
  • \x07Chr(7)(单元格结束符)
  • \x0BChr(11)(垂直制表符)
  • \x0DChr(13)(段落标记)
  1. 替换逻辑Regex.Replace 将匹配项替换为空字符串,实现批量清除

以上的函数只清洗3个符号,我们还有chr(9)、chr(160)

二、清洗5个干扰符号的增强版本

sql 复制代码
' 增强版:同时处理不间断空格(Chr(160))和制表符(Chr(9))Function AdvancedClean(inputText As String) As String    Dim pattern As String = "[\x07\x0B\x0D]|[\xA0]|\t"    Dim cleaned = Regex.Replace(inputText, pattern, Function(m)         Return If(m.Value = Chr(160), " ", "") ' 不间断空格转普通空格    End Function)    Return cleanedEnd Function

能亮点

  1. 使用 |运算符扩展匹配范围
  1. 通过替换函数区分处理:
  • 不间断空格(C``hr(160)) → 转为普通空格
  • 其他干扰符 → 直接删除
  1. \``t显式匹配制表符(C``hr(9))

三、使用示例:

javascript 复制代码
Dim rawText As String = "单元格内容" & Chr(7) & "结尾" & Chr(11) & "多行" & Chr(13) & "文本"Dim cleanText As String = CleanTableText(rawText)' 输出结果: "单元格内容结尾多行文本"

四、关键注意事项

  1. 命名空间必需:确保已导入 System.Text.RegularExpressions

  2. Unicode处理:VB.NET正则默认支持Unicode字符(如中文)

==The end==

==合集==

====若有用,请转发免费学习====

ExcelVBA文章列表

关注看更多文章

相关推荐
yaoxin52112311 分钟前
279. Java Stream API - Stream 拼接的两种方式:concat() vs flatMap()
java·开发语言
@小码农13 分钟前
202512 电子学会 Scratch图形化编程等级考试三级真题(附答案)
服务器·开发语言·数据结构·数据库·算法
Cosmoshhhyyy27 分钟前
《Effective Java》解读第29条:优先考虑泛型
java·开发语言
一路往蓝-Anbo30 分钟前
C语言从句柄到对象 (六) —— 继承与 HAL:父类指针访问子类数据
c语言·开发语言·stm32·嵌入式硬件·物联网
北冥有一鲲33 分钟前
A2A协议与LangChain.js实战:构建微型软件工厂
开发语言·javascript·langchain
Chen不旧40 分钟前
java基于reentrantlock/condition/queue实现阻塞队列
java·开发语言·signal·reentrantlock·await·condition
laplace01231 小时前
Part 3:模型调用、记忆管理与工具调用流程(LangChain 1.0)笔记(Markdown)
开发语言·人工智能·笔记·python·langchain·prompt
风送雨1 小时前
八周Python强化计划(七)
开发语言·python
ππ很开心6661 小时前
DAY 32 函数专题2:装饰器
开发语言·python
Knight_AL1 小时前
阿里《Java 开发手册》下的对象构建与赋值规范实践
java·开发语言