linux 文本替换,linux文本编辑命令

本篇文章给大家谈谈linux 文本替换,以及linux文本编辑命令对应的知识点,文章可能有点长,但是希望大家可以阅读完,增长自己的知识,最重要的是希望对各位有所帮助,可以解决了您的问题,不要忘了收藏本站喔。

Linux系统中tr命令删除和替换文本字符的基本用法

通过使用 tr,您可以非常容易地实现 sed的许多最基本功能。您可以将 tr看作为 sed的(极其)简化的变体:它可以用一个字符来替换另一个字符,或者可以完全除去一些字符。您也可以用它来除去重复字符。这就是所有 tr所能够做的。

tr用来从标准输入中通过替换或删除操作进行字符转换。tr主要用于删除文件中控制字符或进行字符转换。使用tr时要转换两个字符串:字符串1用于查询,字符串2用于处理各种转换。tr刚执行时,字符串1中的字符被映射到字符串2中的字符,然后转换操作开始。

带有最常用选项的tr命令格式为:

代码如下:

tr-c-d-s ["string1_to_translate_from"] ["string2_to_translate_to"] input-file

这里:

-c用字符串1中字符集的补集替换此字符集,要求字符集为ASCII。

-d删除字符串1中所有输入字符。

-s删除所有重复出现字符序列,只保留第一个;即将重复出现字符串压缩为一个字符串。

input-file是转换文件名。虽然可以使用其他格式输入,但这种格式最常用。

字符范围

指定字符串1或字符串2的内容时,只能使用单字符或字符串范围或列表。

[a-z] a-z内的字符组成的字符串。

[A-Z] A-Z内的字符组成的字符串。

[0-9]数字串。

octal一个三位的八进制数,对应有效的ASCII字符。

[O*n]表示字符O重复出现指定次数n。因此[O*2]匹配OO的字符串。

tr中特定控制字符的不同表达方式

速记符含义八进制方式

a Ctrl-G铃声07

b Ctrl-H退格符10

f Ctrl-L走行换页14

n Ctrl-J新行12

r Ctrl-M回车15

t Ctrl-I tab键11

v Ctrl-X 30

表达字符串的特殊序列

String1和 String2变量中所包含的字符串可以使用以下的约定来表示:

如果某个字符在 String1中被指定过多次,则该字符就被转换成 String2中为与 String1中最后出现的字符相对应的字符。

如果由 String1和 String2指定的字符串长度不相同,则 tr命令就会忽略较长一个字符串中的多余字符。

标志

退出状态

该命令返回以下出口值:

实例:

1、将文件file中出现的"abc"替换为"xyz"

复制代码

代码如下:

# cat file| tr"abc""xyz" new_file

【注意】这里,凡是在file中出现的"a"字母,都替换成"x"字母,"b"字母替换为"y"字母,"c"字母替换为"z"字母。而不是将字符串"abc"替换为字符串"xyz"。

2、使用tr命令“统一”字母大小写

(小写--大写)

代码如下:

# cat file| tr [a-z] [A-Z] new_file

(大写--小写)

代码如下:

# cat file| tr [A-Z] [a-z] new_file

3、把文件中的数字0-9替换为a-j

代码如下:

# cat file| tr [0-9] [a-j] new_file

4、删除文件file中出现的"Snail"字符

代码如下:

# cat file| tr-d"Snail" new_file

【注意】这里,凡是在file文件中出现的'S','n','a','i','l'字符都会被删除!而不是紧紧删除出现的"Snail”字符串。

5、删除文件file中出现的换行'n'、制表't'字符

代码如下:

# cat file| tr-d"nt" new_file

不可见字符都得用转义字符来表示的,这个都是统一的。

6、删除“连续着的”重复字母,只保留第一个

代码如下:

# cat file| tr-s [a-zA-Z] new_file

7、删除空行

代码如下:

# cat file| tr-s"n" new_file

8、删除Windows文件“造成”的'^M'字符

代码如下:

# cat file| tr-d"r" new_file

或者

代码如下:

# cat file| tr-s"r""n" new_file

【注意】这里-s后面是两个参数"r"和"n",用后者替换前者

9、用空格符40替换制表符11

代码如下:

# cat file| tr-s"11""40" new_file

10、把路径变量中的冒号":",替换成换行符"n"

代码如下:

# echo$PATH| tr-s":""n"

11、若要将大括号转换为小括号,请输入:

代码如下:

tr'{}''()' textfile newfile

这便将每个{(左大括号)转换成((左小括号),并将每个}(右大括号)转换成)(右小括号)。所有其它的字符都保持不变。

12、若要将大括号转换成方括号,请输入:

代码如下:

tr'{}''[]' textfile newfile

这便将每个{(左大括号)转换成 [(左方括号),并将每个}(右大括号)转换成 ](右方括号)。左方括号必须与一个""(反斜扛)转义字符一起输入。

13、若要将小写字符转换成大写,请输入:

代码如下:

tr'a-z''A-Z' textfile newfile

14、若要创建一个文件中的单词列表,请输入:

代码如下:

tr-cs'[:lower:][:upper:]''[n*]' textfile newfile

这便将每一序列的字符(除大、小写字母外)都转换成单个换行符。*(星号)可以使 tr命令重复换行符足够多次以使第二个字符串与第一个字符串一样长。

15、若要从某个文件中删除所有空字符,请输入:

代码如下:

tr-d'' textfile newfile

16、若要用单独的换行替换每一序列的一个或多个换行,请输入:

代码如下:

tr-s'n' textfile newfile

代码如下:

tr-s'12' textfile newfile

17、若要以“?”(问号)替换每个非打印字符(有效控制字符除外),请输入:

代码如下:

tr-c'[:print:][:cntrl:]''[?*]' textfile newfile

这便对不同语言环境中创建的文件进行扫描,以查找当前语言环境下不能打印的字符。

18、要以单个“#”字符替换字符类中的每个字符序列,请输入:

代码如下:

tr-s'[:space:]''[#*]'

linux中批量查找替换文本内容例子

.批量查找某个目下文件的包含的内容,例如:

# grep-rn"要找查找的文本"./

2.批量查找并替换文件内容。

# sed-i"s/要找查找的文本/替换后的文本/g" `grep-rl"要找查找的文本"./`

sed的其他用法如下:

1、删除行首空格

sed's/^[ ]*//g' filename

sed's/^*//g' filename

sed's/^[[:space:]]*//g' filename

2、行后和行前添加新行

行后:sed's/pattern//n/g' filename

行前:sed's/pattern//n/g' filename

代表pattern

3、使用变量替换(使用双引号)

sed-e"s/$var1/$var2/g" filename

4、在第一行前插入文本

sed-i'1 i/插入字符串' filename

5、在最后一行插入

sed-i'$ a/插入字符串' filename

6、在匹配行前插入

sed-i'/pattern/ i"插入字符串"' filename

7、在匹配行后插入

sed-i'/pattern/ a"插入字符串"' filename

8、删除文本中空行和空格组成的行以及#号注释的行

grep-v ^# filename| sed/^[[:space:]]*$/d| sed/^$/d

find命令

find-name'要查找的文件名'| xargs perl-pi-e's|被替换的字符串|替换后的字符串|g'

#查找替换当前目录下包含字符串并进行替换

find-name'*.txt'| xargs perl-pi-e's|智慧乡村|北部山区|g'

#递归查找替换

find.-type f-name'*.html'| xargs perl-pi-e's|智慧乡村|北部山区|g'

#搜索目录LOG包含显示出来

find./-name'*log*'-type d

find./-name'*Log*'-type d more

当然还可以利用 linux vim批量替换

只对当前行进行替换:

Example

:s/XXX/YYY/g

,如果需要进行全部替换:

Example

:%s/XXX/YYY/g

如果需要对指定部分进行替换,可以用V进入visual模式,再进行

Example

:s/XXX/YYY/g

或者可以指定行数对指定范围进行替换:

Example

:10,31s/XXX/YYY/g

若需要显示行号,在vim下

Example

:set nu

取消显示行号:

Example

:set nonu

:s/well/good/替换当前行第一个 well为 good

:s/well/good/g替换当前行所有 well为 good

:n,$s/well/good/替换第 n行开始到最后一行中每一行的第一个 well为 good

:n,$s/well/good/g替换第 n行开始到最后一行中每一行所有 well为 good

n为数字,若 n为.,表示从当前行开始到最后一行

:%s/well/good/(等同于:g/well/s//good/)替换每一行的第一个 well为 good

:%s/well/good/g(等同于:g/well/s//good/g)替换每一行中所有 well为 good

可以使用#作为分隔符,此时中间出现的/不会作为分隔符

:s#well/#good/#替换当前行第一个 well/为 good/

:%s#/usr/bin#/bin#g可以把文件中所有路径/usr/bin换成/bin

Linux sed 文本替换

Linux的sed工具,作为强大的流编辑器,以其灵活的正则表达式功能闻名。本文将深入解析sed在文本替换操作中的实用技巧。

首先,sed的核心功能就是替换文本,无论是替换单个字符串,如:$ sed's/pattern/replace_string/' file,还是替换所有匹配,只需在命令末尾加上g,如$ sed's/pattern/replace_string/g' file。

如果目标是替换从特定位置开始的内容,如从第n行开始,可使用/Ng选项。另外,sed能高效处理空白行,通过正则表达式^$匹配并剔除。

在替换过程中,sed允许引用已匹配的字符串,使用&符号。同时,子串匹配标记如\1,用于引用样式中的特定部分。例如,([a-z]+)匹配第一个单词,([A-Z]+)匹配第二个,然后通过\1和\2进行反向引用,以实现特定的替换效果。

总之,Linux sed的文本替换功能强大且灵活,熟练掌握这些技巧将大大提高文本处理的效率。通过结合正则表达式,你可以精准地替换、定位和引用文本内容。

阅读剩余
THE END