awk 출력에서 ​​문자열 인용

awk 출력에서 ​​문자열 인용

awk아래 표시된 방법을 사용하여 파일에서 문자열을 가져옵니다. 이제 나는 그것을 큰따옴표로 묶고 싶습니다. 어떤 지원이라도 대단히 감사하겠습니다.

awk -F',' '{print $(NF)}' sample.csv|  tail +2  

산출:

sample

예상 출력:

"sample"

답변1

문자열에 따옴표를 추가하려면 awk따옴표 붙은 문자열을 인쇄하세요.

print "\"" $NF "\""

또는

printf "\"%s\"\n", $NF

이렇게 하면 이미 인용된 필드에 인용이 추가됩니다.

CSV 인식 도구 사용밀러( mlr)는 헤더(따옴표 포함)는 Data있지만 CSV 헤더는 없는 필드를 추출합니다.

mlr --csv --headerless-csv-output --quote-all cut -f Data file.csv

이렇게 하면 이미 인용된 필드에 따옴표가 추가되지 않지만 삽입된 쉼표, 따옴표 및 개행이 포함된 필드가 올바르게 반환되므로 awk쉽지 않습니다.


CSV 파일의 모든 데이터를 참조하고 해당 파일을 원본 파일에 다시 쓰려면 다음과 같이 Miller를 사용합니다.

mlr --csv --quote-all -I cat file.csv

-I옵션을 사용하면 mlr내부 편집이 수행됩니다. --quote-numeric참조 번호 필드만 사용할 수도 있습니다 . 다른 방법으로 참조를 추가하는 것은 별 의미가 없습니다. 적어도 CSV를 지원하는 도구로 데이터를 읽을 때는 그렇지 않습니다. 일반적인 CSV 처리 도구제거하다기본적으로 인용이 필요하지 않습니다.

관련 정보