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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听