全部博文(668)
分类:
2008-07-08 16:34:15
所有使用者
cut { -b List [ -n ] | -c List | -f List [ -s ] [ -d Character ] } [ File ... ]
cut 命令从文件的每一行剪切字节、字符和字段并将这些字节、字符和字段写至标准输出。 如果不指定 File 参数,cut 命令将读取标准输入。必须指定 -b、-c 或 -f 标志之一。
-b List 指定字节位置。这些字节位置将忽略多字节字符边界,除非也指定了 -n 标志。 -c List 指定字符位置。例如,如果您指定 -c 1-72,cut 命令将写出文件每一行的头 72 个字符。 -d Character 使用 Character 变量指定的字符作为指定 -f 标志时的字段定界符。您必须在对 shell
有特殊意义的字符(比如空格字符)上加上引号。 -f List 指定文件中设想被定界符(缺省情况下为制表符)隔开的字段的列表。例如,如果您指定 -f 1,7,cut
命令将仅写出每个行的第一和第七个字段。如果行中不包含字段定界符,cut 命令将通过它们而不对其进行任何操作
(对表格的副标题有用),除非指定了 -s 标志。 -n 取消分割多字节字符。仅和 -b 标志一起使用。如果字符的最后一个字节落在由 -b 标志的 List 参数指示的
范围之内,该字符将被写出;否则,该字符将被排除。 -s 取消不包含定界符的行。仅和 -f 标志一起使用。
cut -f 1,5 -d: /etc/passwd 这将显示系统密码文件的登录名称和完整用户名称字段。这是第一和第五个字段(-f 1,5),由冒号(-d:)隔开。 例如,如果 /etc/passwd 文件像这样: su:*:0:0:User with special privileges:/:/usr/bin/sh daemon:*:1:1::/etc: bin:*:2:2::/usr/bin: sys:*:3:3::/usr/src: adm:*:4:4:System Administrator:/var/adm:/usr/bin/sh pierre:*:200:200:Pierre Harper:/home/pierre:/usr/bin/sh joan:*:202:200:Joan Brown:/home/joan:/usr/bin/sh cut 命令将产生如下结果: su:User with special privileges daemon: bin: sys: adm:System Administrator pierre:Pierre Harper joan:Joan Brown
cut -f "1 2 3" -d: /etc/passwd cut 命令将产生如下结果: su:*:0 daemon:*:1 bin:*:2 sys:*:3 adm:*:4 pierre:*:200 joan:*:202