쉘 명령을 사용하여 ascii 파일의 처음 n 줄을 어떻게 삭제합니까? 포함 된 여러 파일이 있고 잘 짜여진

첫 5-10 줄에 ASCII 텍스트 정보가 포함 된 여러 파일이 있고 잘 짜여진 행렬 정보가 있습니다. 쉘 스크립트에서 다른 프로그램에서 순수한 행렬 정보를 사용할 수 있도록 처음 몇 줄의 텍스트를 제거하고 싶습니다. bash 쉘 명령을 사용하여 어떻게 할 수 있습니까?

도움이된다면 RedHat과 Ubuntu Linux 시스템을 사용하고 있습니다.



답변

파일이 심볼릭 링크 나 하드 링크가 아닌 경우 sed, tail 또는 awk를 사용할 수 있습니다. 아래 예.

$ cat t.txt
12
34
56
78
90

sed

$ sed -e '1,3d' < t.txt
78
90

임시 파일없이 sed를 제자리에서 사용할 수도 있습니다 sed -i -e 1,3d yourfile. 아무 것도 에코하지 않고 파일을 제자리에서 수정합니다. 결과를 다른 명령으로 파이프 할 필요가 없으면 더 쉽습니다.

꼬리

$ tail -n +4 t.txt
78
90

어 wk

$ awk 'NR > 3 { print }' < t.txt
78
90


답변

sed -i '1,3d' file.txt

file.txt에서 처음 3 줄을 삭제합니다.


답변

테이블 라인이 탭 문자가있는 라인 인 경우 :

grep '␉' <input_file >output_file

( 리터럴 탭 문자) 또는 동등

sed -n '/␉/p' <input_file >output_file

bash / ksh / zsh 스크립트에서 $'\t'탭을 작성할 수 있습니다 ( 예 : grep $'\t'또는) sed -n $'/\t/p'.

파일 시작 부분에서 10 줄을 제거하려면 다음을 수행하십시오.

tail -n +11 <input_file >output_file

( “11 행에서 시작”을 의미하고 1에서 꼬리 행을 의미 +11하기 때문에 10 행을 제거 해야합니다 +11) 또는

sed '1,10d' <input_file >output_file

Linux에서는 GNU sed의 -i옵션을 사용하여 파일을 적절 하게 수정할 수 있습니다.

sed -i -n '/\t/p' *.txt

또는 쉘 루프와 임시 파일을 사용할 수 있습니다.

for x in *.txt; do
  tail -n +11 <"$x" >"$x.tmp"
  mv "$x.tmp" "$x"
done

또는 파일을 제자리에 수정하지 않고 대신 다른 이름을 지정하십시오.

for x in *.txt; do
  tail -n +11 <"$x" >"${x%.txt}.data"
done


답변

Ex 모드에서 Vim을 사용할 수 있습니다 :

ex -sc '1d5|x' file
  1. 1 첫 줄로 이동

  2. 5 5 줄을 선택하십시오

  3. d 지우다

  4. x 저장하고 닫습니다


답변

에코 “a \ nb”| sed ‘1d’# 첫 줄 삭제

고양이 list.txt | sed ‘1d’> list.csv # list.txt를 읽고 첫 줄없이 list.csv를 씁니다.

다른 유용한 명령들 :

grep ‘^ |’ # 첫 문자를 찾습니다 (pipe |)

sed ‘s / | // g’# 파이프 삭제

sed ‘s / // g’# 공간을 삭제합니다


답변

백분율로

을 사용 bash하여 절대 줄 수 대신 백분율 숫자를 사용하여 파일을 정리하십시오.

sed -i -e 1,$( printf  "$((`cat php_errors.log | wc -l` * 75 /100 ))" )d php_errors.log

사본을 작성하지 않고 내부에서 컨텐츠를 삭제하므로 해당 명령이 손상 될 수 있으므로주의하십시오.

언급 된 파일에서 처음 75 %의 행을 삭제합니다.


답변