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

相关文章

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

Java Stream 并行流简介、使用与注意事项小结

《JavaStream并行流简介、使用与注意事项小结》Java8并行流基于StreamAPI,利用多核CPU提升计算密集型任务效率,但需注意线程安全、顺序不确定及线程池管理,可通过自定义线程池与C... 目录1. 并行流简介​特点:​2. 并行流的简单使用​示例:并行流的基本使用​3. 配合自定义线程池​示

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

Java Kafka消费者实现过程

《JavaKafka消费者实现过程》Kafka消费者通过KafkaConsumer类实现,核心机制包括偏移量管理、消费者组协调、批量拉取消息及多线程处理,手动提交offset确保数据可靠性,自动提交... 目录基础KafkaConsumer类分析关键代码与核心算法2.1 订阅与分区分配2.2 拉取消息2.3

SpringBoot集成XXL-JOB实现任务管理全流程

《SpringBoot集成XXL-JOB实现任务管理全流程》XXL-JOB是一款轻量级分布式任务调度平台,功能丰富、界面简洁、易于扩展,本文介绍如何通过SpringBoot项目,使用RestTempl... 目录一、前言二、项目结构简述三、Maven 依赖四、Controller 代码详解五、Service

Java中HashMap的用法详细介绍

《Java中HashMap的用法详细介绍》JavaHashMap是一种高效的数据结构,用于存储键值对,它是基于哈希表实现的,提供快速的插入、删除和查找操作,:本文主要介绍Java中HashMap... 目录一.HashMap1.基本概念2.底层数据结构:3.HashCode和equals方法为什么重写Has