เครื่องมือเชลล์เพื่อ“ ป้อนข้อมูล” tablify


33

นานมาแล้วฉันจำได้ว่าใช้คำสั่งที่ทำให้มันเข้าสู่ตารางในรูปแบบที่ดี

ตัวอย่างเช่นสำหรับอินพุตนี้

apple 1 100
orange 20 19
pineapple 1000 87
avocado 4 30

ผลลัพธ์จะคล้ายกับสิ่งนี้:

apple     1    100
orange    20   19
pineapple 1000 87
avocado   4    30

ฉันต้องการทราบชื่อของเครื่องมือนี้

คำตอบ:



0

awk โซลูชันที่เกี่ยวข้องกับ stdin

เนื่องจากcolumnไม่ใช่ POSIX อาจเป็นเพราะ:

mycolumn() (
  file="${1:--}"
  if [ "$file" = - ]; then
    file="$(mktemp)"
    cat >"${file}"
  fi
  awk '
  FNR == 1 { if (NR == FNR) next }
  NR == FNR {
    for (i = 1; i <= NF; i++) {
      l = length($i)
      if (w[i] < l)
        w[i] = l
    }
    next
  }
  {
    for (i = 1; i <= NF; i++)
      printf "%*s", w[i] + (i > 1 ? 1 : 0), $i
    print ""
  }
  ' "$file" "$file"
  if [ "$file" = - ]; then
    rm "$file"
  fi
)

ทดสอบ:

printf '12 1234 1
12345678 1 123
1234 123456 123456
' > file

คำสั่งทดสอบ:

mycolumn file
mycolumn <file
mycolumn - <file

ผลผลิตสำหรับทุกคน:

      12   1234      1
12345678      1    123
    1234 123456 123456

ดูสิ่งนี้ด้วย:


0

สำหรับไฟล์ที่มีขนาดค่อนข้างเล็ก (โดยที่ความยาวเป็นไบต์น้อยกว่าgetconf ARG_MAX) และขนาดอินพุตเป็นที่รู้จักมากขึ้นหรือน้อยลง (สมมติว่าไม่มีชื่อผลไม้ที่มีความยาวมากกว่า 18 ตัวอักษร) printfมีประโยชน์นี่คือbashตัวอย่าง:

 printf '%-20s %5s %5s\n' $(<file.txt)

เอาท์พุท:

apple                    1   100
orange                  20    19
pineapple             1000    87
avocado                  4    30

สังเกตว่าตัวเลขมีความถูกต้องหรือไม่

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.