집 >운영 및 유지보수 >리눅스 운영 및 유지 관리 >Linux에서 sed 명령에 대한 샘플 코드 공유에 대한 자세한 설명
sed는 콘텐츠를 한 번에 한 줄씩 처리하는 온라인 editor입니다. 처리하는 동안 현재 처리된 라인은 "패턴 공간"이라는 임시 버퍼에 저장되고, 이후 sed 명령을 사용하여 버퍼의 내용을 처리한 후 버퍼의 내용이 전송됩니다. 화면. 그런 다음 다음 줄을 처리하고 파일 끝까지 반복합니다. 출력을 저장하기 위해 리디렉션을 사용하지 않는 한 파일 내용은 변경되지 않습니다. Sed는 주로 하나 이상의 파일을 자동으로 편집하는 데 사용됩니다. 파일에 대한 반복 작업 등을 단순화합니다.
[root@www ~]# sed [-nefr] [动作]
옵션 및 매개변수:
-n: 자동 모드를 사용합니다. 일반적인 sed 사용에서는 STDIN에서 오는 모든 데이터가 일반적으로 터미널에 나열됩니다. 하지만 -n 매개변수를 추가하면 sed에서 특별히 처리한 라인(또는 액션)만 나열됩니다.
-e: 명령줄 모드에서 직접 sed 작업을 편집합니다.
-f: 파일에 sed 작업을 직접 작성합니다. -f filename은 파일 이름에서 sed 작업을 실행할 수 있습니다.
-r: sed 작업이 지원됩니다. 확장 정규식의 구문. (기본값은 기본 정규 표기법 구문)
-i: 읽은 파일의 내용을 터미널에 출력하는 대신 직접 수정합니다.
작업 설명: [n1[,n2]]function
n1, n2: 존재하지 않을 수 있으며 일반적으로 "작업에 대한 줄 수 선택"을 나타냅니다. 예를 들어 내 작업이 10~20줄 사이에 있어야 하는 경우 10,20 [ActionBehavior] ]
function:
a:New, a 뒤에 문자열이 올 수 있으며 이 문자열은 새 줄(현재는 다음 줄)에 나타납니다~
c: 교체 , c 뒤에는 문자열이 올 수 있으며 이러한 문자열은 n1과 n2 사이의 줄을 대체할 수 있습니다!
d: delete, 삭제이므로 d 뒤에는 일반적으로 동동이 없습니다.
i: 삽입, i 뒤에 문자열이 올 수 있으며 이 문자열은 새 줄(현재 이전 줄)에 나타납니다. ;
p: 인쇄, 즉 선택한 데이터를 인쇄합니다. 보통 p는 sed -n~
s 매개변수와 함께 실행됩니다. 교체, 교체 작업을 직접 수행할 수 있습니다! 일반적으로 이 작업은 일반 표기법과 짝을 이룰 수 있습니다! 예를 들어 1,20s/old/new/g입니다.
/etc/passwd 내용을 나열하고 라인 번호를 출력하면서 2~5라인을 삭제해주세요!
[root@www ~]# nl /etc/passwd | sed '2,5d' 1 root:x:0:0:root:/root:/bin/bash 6 sync:x:5:0:sync:/sbin:/bin/sync 7 shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown .....(后面省略).....
sed의 액션은 '2,5d'이고, 그 d는 삭제입니다! 그가 2-5행을 삭제했기 때문에 표시된 데이터에는 2-5행이 포함되지 않습니다~ 또한 원래는 sed -e를 실행했어야 했지만 -e 없이도 작동한다는 점에 유의하세요! 동시에, sed 다음에 오는 작업은 두 개의 작은따옴표 ''로 묶어야 한다는 점도 주의해야 합니다!
nl /etc/passwd | sed '2d'
nl /etc/passwd | sed '3,$d'
[root@www ~]# nl /etc/passwd | sed '2a new line text' 1 root:x:0:0:root:/root:/bin/bash 2 bin:x:1:1:bin:/bin:/sbin/nologin new line text 3 daemon:x:2:2:daemon:/sbin:/sbin/nologin .....(后面省略).....
2~5행의 내용을 두 번째 줄
nl /etc/passwd | sed '2i new line text'
[root@www ~]# nl /etc/passwd | sed '2,5c No 2-5 number' 1 root:x:0:0:root:/root:/bin/bash No 2-5 number 6 sync:x:5:0:sync:/sbin:/bin/sync .....(后面省略).....
/etc/passwd 파일에서 5-7행만 나열하세요
[root@www ~]# nl /etc/passwd | sed -n '5,7p' 5 lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin 6 sync:x:5:0:sync:/sbin:/bin/sync 7 shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
데이터 검색 및 표시
루트 키워드가 있는 줄을nl /etc/passwd | sed '/root/p' 1 root:x:0:0:root:/root:/bin/bash 1 root:x:0:0:root:/root:/bin/bash 2 daemon:x:1:1:daemon:/usr/sbin:/bin/sh 3 bin:x:2:2:bin:/bin:/bin/sh 4 sys:x:3:3:sys:/dev:/bin/sh 5 sync:x:4:65534:sync:/bin:/bin/sync ....下面忽略루트가 발견되면 모든 줄을 출력하는 것 외에도 일치하는 줄도 출력합니다.
-n을 사용하면 템플릿이 포함된 줄만 인쇄됩니다.
nl /etc/passwd | sed -n '/root/p' 1 root:x:0:0:root:/root:/bin/bash
데이터 검색 및 삭제
nl /etc/passwd | sed '/root/d' 2 daemon:x:1:1:daemon:/usr/sbin:/bin/sh 3 bin:x:2:2:bin:/bin:/bin/sh ....下面忽略 #第一行的匹配root已经删除了
명령어 검색 및 실행
/etc/passwd 검색 , 루트에 해당하는 줄을 찾고 중괄호로 묶인 명령 세트를 실행하고 각 명령을 세미콜론으로 구분하고 bash를 blueshell로 바꾼 다음 다음 줄을 출력합니다.
nl /etc/passwd | sed -n '/root/{s/bash/blueshell/;p}' 1 root:x:0:0:root:/root:/bin/blueshell
/etc/passwd만 바꾸는 경우 첫 번째 bash 키워드 blueshell은
Exitnl /etc/passwd | sed -n '/bash/{s/bash/blueshell/;p;q}'
1 root:x:0:0:root:/root:/bin/blueshell
을 의미합니다. 마지막 q는 종료입니다.
데이터 검색 및 교체
sed 's/교체할 문자열/새 문자열/g'
먼저 원본 정보를 관찰하고 /sbin/
ifconfig를 사용하여 IP 쿼리를 수행합니다. 本机的ip是192.168.1.100。 接下来则是删除后续的部分,亦即: 192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0 一条sed命令,删除/etc/passwd第三行到末尾的数据,并把bash替换为blueshell nl /etc/passwd | sed -e '3,$d' -e 's/bash/blueshell/' 1 root:x:0:0:root:/root:/bin/blueshell 2 daemon:x:1:1:daemon:/usr/sbin:/bin/sh -e表示多点编辑,第一个编辑命令删除/etc/passwd第三行到末尾的数据,第二条命令搜索bash替换为blueshell。 sed 可以直接修改文件的内容,不必使用管道命令或数据流重导向! 不过,由於这个动作会直接修改到原始的文件,所以请你千万不要随便拿系统配置来测试! 我们还是使用下载的 regular_express.txt 文件来测试看看吧! 利用 sed 将 regular_express.txt 内每一行结尾若为 . 则换成 ! 利用 sed 直接在 regular_express.txt 最后一行加入『# This is a test』 由于 $ 代表的是最后一行,而 a 的动作是新增,因此该文件最后新增『# This is a test』! sed 的『 -i 』选项可以直接修改文件内容,这功能非常有帮助!举例来说,如果你有一个 100 万行的文件,你要在第 100 行加某些文字,此时使用 vim 可能会疯掉!因为文件太大了!那怎办?就利用 sed 啊!透过 sed 直接修改/取代的功能,你甚至不需要使用 vim 去修订![root@www ~]# /sbin/ifconfig eth0
eth0 Link encap:Ethernet HWaddr 00:90:CC:A6:34:84
inet addr:192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0
inet6 addr: fe80::290:ccff:fea6:3484/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
.....(以下省略).....
将 IP 前面的部分予以删除
[root@www ~]# /sbin/ifconfig eth0 | grep 'inet addr' | sed 's/^.*addr://g'
192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0
将 IP 后面的部分予以删除
[root@www ~]# /sbin/ifconfig eth0 | grep 'inet addr' | sed 's/^.*addr://g' | sed 's/Bcast.*$//g'
192.168.1.100
多点编辑
直接修改文件内容(危险动作)
[root@www ~]# sed -i 's/\.$/\!/g' regular_express.txt
[root@www ~]# sed -i '$a # This is a test' regular_express.txt
위 내용은 Linux에서 sed 명령에 대한 샘플 코드 공유에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!