파일 디렉토리가 있습니다. 각 파일에는 한 줄이 포함됩니다.
# order: N
여기서 N은 정수입니다. 해당 N 번호를 기반으로 디렉터리의 모든 파일을 나열하고 싶습니다(래퍼 스크립트에도 포함). bash 명령줄을 통해 이를 달성할 수 있습니까?
답변1
GNU를 사용 grep
하고 파일 이름에 콜론이나 개행 문자가 포함되어 있지 않다고 가정합니다.
$ ls
bar baz foo freeble quux
$ cat ./*
# order: 3
# order: 2
# order: 1
# order: 4
# order: 5
$ grep -m1 -EH '^# order: [0-9]+$' ./* | sort -n -k3 | cut -d: -f1
foo
baz
bar
freeble
quux
답변2
단일 GNU 사용awk
프로세스:
awk 'BEGIN{ PROCINFO["sorted_in"]="@val_num_asc" }
/order: [0-9]+/{ a[FILENAME]=$NF; nextfile }
END{ for(i in a) print i }' ./*
답변3
를 사용하면 zsh
다음 줄의 내용을 기반으로 전역 정렬 순서를 정의할 수 있습니다.
byOrder() REPLY=$(grep '^# order:' < $REPLY)
그런 다음 예를 들어 사용하십시오.
printf '%s\n' *(.no+byOrder)
또는
sorted_file_list=(*(.no+byOrder))
.
(또한 glob 한정자에 a를 추가하여정기적인파일(디렉토리, fifo, 심볼릭 링크가 아님...)).