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

2024-03-15 00:30

本文主要是介绍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

这篇关于java 文本编辑器替换特殊字符_【已解决】替换掉VSCode中显示出的特殊字符:NAK...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/810221

相关文章

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1