java 文本编辑器替换特殊字符_【已解决】替换掉VSCode中显示出的特殊字符:NAK...

现有一个文件,用VSCode打开,发现里面:

显示出了NAK这种特殊不可见字符:

9c413a1f4dff947baf69a2cd998340ff.png

(注:

之前一直是开启显示控制字符:

8b8e828d6e82e560201ccc15a74b5791.png

所以此处才能看到这些特殊的,不可见的,控制字符的)

NAK

此处需要:

搞清楚NAK的含义

以及:

替换掉:

NAK\d+_\d+NAK

为空

之前自己整理过,

所以去找:

crifan 不可见字符十

进制十六

进制控制

字符转义

字符*说明Ctrl +

下列字母*

2115NAKNegative Acknowledgement(拒绝接收/无响应)U

1a05e60c211bf75a6ab4deeb86b3724a.png

21是NAK=Negative Acknowledgement(拒绝接收/无响应)

所以接着就是去搞清楚:

VSCode中的正则,如何输入表达

ASCII中特殊的不可见字符NAK

或者说  unicode字符

VSCode 正则 特殊字符

继续参考之前找到的:

->

->

去看看,如何写unicode字符

好像可以参考:\x7F       hex character code (exactly two digits)

去写hex 16进制值,试试

ASCII的NAK=10进制是12=16进制是0x15

结果无效:

34e15759c8e052b3f560b9d7c70df2db.png

再去参考:\x{10FFFF} any hex character code corresponding to a Unicode code point

试试unicode的code point

不过先去查查NAK的unicode的code point

unicode code point

unicode code point NAK

结果:\x{0015}\d+_\d+

也不行,匹配不到:

5db5669b47f15af9253d9b5517a55e17.png

VSCode regex special char\u0015

\u15

都不行。

VSCode regex unicode

32cf3b0d6d5d156f2d45e6f83c173781.png

我这里试了:\u0015

\u15

还是不行啊

去试试[\u0015]

[\u15]

都可以的,能找到字符的:

8c85094d074dd7741e20e50cfd6a4b67.png

然后去用:^[\u0015]\d+_\d+[\u0015]$

去掉这些有问题的单词

53ac7b200fea35654b27dfc6aba574bb.png

cd17e79b911a921398a5f6c428c56e25.png

然后再去顺带把多余的空行去掉\n\n+

\n

415933e696304c4b3fba0d3df2c24a5b.png

9088f94216203d2b348d6f7fa2f770a3.png

而此处:\u0015

之所以没有生效。

后来经过自己的细心和观察和猜测:

帖子2017年的,感觉是:

\uxxxx

VSCode应该是2017年就知道了

而此处

可以

-》

而对方是js代码

-〉但是我这里不可以。

-》难道是\uxxxx只有在js代码中的才有效?

-〉之所以这么测试是因为看到了:

提到了:

“one search engine uses theJavaScript regular expressionsyntax (albeit without the ‘u’ unicode flag),

the other is based onripgrepwhich usesRust regular expressionsyntax.”

即:

VSCode中用了两套正则的库:JS的正则表达式的库

ripgrep:内部是基于Rust正则表达式的库也就是我们之前找到的那个文档:regex – Rust

去试了试:

把其中部分内容,拷贝出来,设置代码语法是js,然后再去试试:\u0015,还真的可以:

19b384bf04c4e9feaf7f380d30cc239e.png

-》证明了我的猜测是对的。

【后记】

后来重新试了,csv文件中:\u0015

是生效的:

d0982eec9409a24e950b63924181d55d.png\u0015\d+_\d+\u0015

替换为:

1bba89890689ab048cbb82fc32054137.png

再去:\n\n+

\n

84dc829caf48cc371a70dd4c0cbdb4cd.png

3e59850d6340a5abe722a3f5ea4343ac.png

把文件从39M变成3.4M了:

32b9c4743aa24491a14db24a61038275.png

【总结】

VSCode中,如果使用查找(和替换的话),其中用到了正则的话

-〉在搜索中,选中了那个:.* 的图标

2de9070d4e8662f06281465d5617c2f5.png

-》

按照之前说法,好像有两套正则:JS的正则Regular Expressions – JavaScript | MDN

-》unicode(和hex的16进制)写法是:\xhhMatches the character with the code hh (two hexadecimal digits)

\uhhhhMatches the character with the code hhhh (four hexadecimal digits).

\u{hhhh}(only when u flag is set) Matches the character with the Unicode value hhhh (hexadecimal digits).

基于Rust的ripgrep调用的是:

regex – Rust

-》unicode(和hex的16进制)的写法是:\x7Fhex character code (exactly two digits)

\x{10FFFF}any hex character code corresponding to a Unicode code point

\u007Fhex character code (exactly four digits)

\u{7F}any hex character code corresponding to a Unicode code point

\U0000007Fhex character code (exactly eight digits)

\U{7F}any hex character code corresponding to a Unicode code point

-》不过不用操心,此处

VSCode版本是最新的:1.24.1

对于unicode,都支持:\u0015

的写法,即可找到NAK这个特殊字符了。

另外:新版Rust的unicode支持更完整:

之前0.25的旧版本的Rust:

是:\x7F       hex character code (exactly two digits)

\x{10FFFF} any hex character code corresponding to a Unicode code point

而新版本1.0

是:\x7F        hex character code (exactly two digits)

\x{10FFFF}  any hex character code corresponding to a Unicode code point

\u007F      hex character code (exactly four digits)

\u{7F}      any hex character code corresponding to a Unicode code point

\U0000007F  hex character code (exactly eight digits)

\U{7F}      any hex character code corresponding to a Unicode code point

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值