ejemplo de uso del comando linux sed

Tabla de contenido

1. Introducción

Dos, parámetros de uso sed

2.1. Agregar / eliminar por unidad de línea

2.2. Sustitución y visualización por unidad de línea

2.3. Búsqueda y visualización de datos

2.4. Búsqueda y eliminación de datos

2.5. Buscar datos y ejecutar comandos

2.6. Buscar y reemplazar datos


1. Introducción

Sed es un editor en línea que procesa el contenido una línea a la vez. Durante el procesamiento, la línea procesada actualmente se almacena en un búfer temporal llamado "espacio de patrón", y luego el contenido en el búfer se procesa con el comando sed. Una vez completado el procesamiento, el contenido del búfer se envía a la pantalla. Luego procese la siguiente línea y repita de esta manera hasta el final del archivo. El contenido del archivo no cambia a menos que use la redirección para almacenar la salida. Sed se utiliza principalmente para editar automáticamente uno o más archivos; simplificar operaciones repetidas en archivos; escribir programas de conversión, etc.

Dos, parámetros de uso sed

[root@client ~]# sed
选项与参数:
-n :使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN 的数据一般都会被列出到终端上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
-e :直接在命令列模式上进行 sed 的动作编辑;
-f :直接将 sed 的动作写在一个文件内, -f filename 则可以运行 filename 内的 sed 动作;
-r :sed 的动作支持的是延伸型正规表示法的语法。(默认是基础正规表示法语法)
-i :直接修改读取的文件内容,而不是输出到终端。

动作说明: [n1[,n2]]function
n1, n2 :不见得会存在,一般代表『选择进行动作的行数』,举例来说,如果我的动作是需要在 10 到 20 行之间进行的,则『 10,20[动作行为] 』

function:
a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
d :删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
p :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行~
s :取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!

2.1. Agregar / eliminar por unidad de línea

 1. Enumere el contenido de deviceInfo.txt e imprima el número de línea. Al mismo tiempo, elimine las líneas 2 ~ 5.

[root@client kangll]# nl deviceInfo.txt | sed '2,5d'

¡La acción de sed es '2,5d', y esa d es borrar! Debido a que la línea 2-5 fue eliminada para él, los datos mostrados no son la línea 2-5 ~ Además, tenga en cuenta que sed -e debería haberse emitido originalmente, está bien sin -e! Al mismo tiempo, tenga en cuenta que la acción que sigue a sed debe estar entre comillas simples.

2. Elimina la segunda línea o el contenido entre la segunda y la última línea.

3. Después de la segunda línea (es decir, agréguela a la tercera línea), agregue la palabra "kangll"

4. Agrega "kangll" antes de la segunda línea.

[root@client kangll]# nl deviceInfo.txt | sed '2i kangll'

2.2. Sustitución y visualización por unidad de línea

1. Reemplace el contenido de las líneas 2-5 con [No 2-5 number]

[root@client kangll]# nl deviceInfo.txt | sed '2,5c No 2-5 Number'

2. Enumere solo las líneas 3 a 6 del archivo deviceInfo.txt

### 只显示 3,6 行的内容
[root@client kangll]# nl deviceInfo.txt | sed -n '3,6p'
     3	T0905,T0000000001,120.23.34.123,3,2016-6-19 0:00,2016-6-19 16:04,
     4	T0905,T0000000001,111.23.34.21,9,2016-6-22 0:00,2016-6-22 13:02,
     5	T0905,T0000000001,111.23.34.21,5,2016-6-22 0:00,2016-6-22 16:23,
     6	t9.ipva.cn,T0000000001,120.23.34.21,1,2016-6-23 0:00,2016-6-23 10:53,

2.3. Búsqueda y visualización de datos

 nl sed_test.txt | sed '/T0908.ipva.cn/p'

Al usar sed -n solo imprime líneas que contienen coincidencias 

[root@datanode01 kangll]# nl sed_test.txt | sed -n '/T0908.ipva.cn/p'  # 只会输出 匹配行
     1  T0908.ipva.cn,T1111111111,111.111.111.111,0,2020-06-29T10:10:30+08:00,2020-06-29 10:15,

2.4. Búsqueda y eliminación de datos

[root@datanode01 kangll]# nl sed_test.txt | sed '/T0908.ipva.cn/d'

2.5. Buscar datos y ejecutar comandos

Busque la línea correspondiente a [T0908.ipva.cn] en sed_test.txt, ejecute un conjunto de comandos en las llaves, separe cada comando con un punto y coma, reemplace [111.111.111.111] con [1.1.1.1]. línea

2.6. Buscar y reemplazar datos

Además del modo de procesamiento de toda la línea, sed también puede buscar y reemplazar parte de los datos con la unidad de línea. Básicamente, la búsqueda y sustitución de sed es bastante similar a vi! Él es un poco así:

sed 's/要被取代的字串/新的字串/g'
# 查看原始的数据
[root@datanode01 kangll]# nl sed_test.txt
     1  T0908.ipva.cn,T1111111111,111.111.111.111,0,2020-06-29T10:10:30+08:00,2020-06-29 10:15,
     2  T0907.ipva.cn,T2000000102,120.110.34.21,12,2016-06-23 09:53:00,2020-06-23 09:53,
     3  T0906.ipva.cn,T3000000102,120.110.34.21,12,2020-06-22T15:34:30+08:00,2019-04-13 2:06,
     4  T0905.ipva.cn,T4000000104,120.110.34.21,12,2020-06-22T15:34:30+08:00,2019-04-18 2:44,
     5  T0904.ipva.cn,T5000000105,120.110.34.21,12,2020-06-22T15:34:30+08:00,2019-08-24 6:20,
# 搜索 [T5000000105] 这个设备 将  ‘T’ 之前的内容删掉
[root@datanode01 kangll]# nl sed_test.txt | grep T5000000105 | sed 's/^.*T//g'
15:34:30+08:00,2019-08-24 6:20,
#  搜索 [T5000000105] 这个设备 将  ‘T’ 之前的内容删掉  ,再将  ‘,’之后的内容删掉
[root@datanode01 kangll]# nl sed_test.txt | grep T5000000105 | sed 's/^.*T//g' | sed 's/,.*$//g'
15:34:30+08:00
[root@datanode01 kangll]#

 

 

 

 

 

 

 

 

 

 

 

Supongo que te gusta

Origin blog.csdn.net/qq_35995514/article/details/112099905
Recomendado
Clasificación