Linux の cut コマンドの説明

Linux の cut コマンドの説明

Linux や Unix の cut コマンドは、ファイルの各行から一部を切り取って標準出力に出力するために使用されます。 cut コマンドを使用すると、バイト、文字、フィールド (区切り文字) などの単位で文字列の行からコンテンツの一部を抽出できます。

この記事では、いくつかの例を通して cut コマンドの使い方について学びます。これらの使用方法は、日常業務でも非常によく使用されます。

カットコマンドと構文

cut コマンドの基本的な構文は次のとおりです。

$ cut オプション... [ファイル]...

まず、cut のオプションをいくつか見てみましょう。cut コマンドは、実行するオプションとともに指定する必要があります。

-f : 指定されたフィールドを抽出します。cut コマンドは、デフォルトの区切り文字としてタブを使用します。

-d : タブはデフォルトの区切り文字です。このオプションを使用して独自の区切り文字を指定します。

-b : 指定されたバイトを抽出するか、範囲を指定します。

-c : 指定された文字を抽出します。指定された文字は、カンマで区切られた数字のリスト、またはハイフンで区切られた数字の範囲になります。

–complement : 選択した部分を補完します。つまり、選択範囲を反転します。

–output-delimiter : 出力時に使用される区切り文字を変更します。

--only-delimited : 区切り文字を含まない列を出力しません。

説明のために、 context.txtという名前の次のテキスト ファイルと/etc/passwdファイルを例に挙げます。

$ 猫コンテンツ.txt 
Ubuntu Linux
マイクロソフトウィンドウズ
OSX エルキャピタン
ユニックス
フリーBSD

区切り文字の指定方法

最もよく使用されるオプションは-d-fの組み合わせで、 -dで指定された区切り文字と-fでリストされたフィールドに基づいてコンテンツを抽出します。

たとえば、この例では、/etc/passwd ファイルの各行の最初のフィールドのみが印刷され、使用される区切り文字は次のとおりです:

$ カット -d':' -f1 /etc/passwd
根
ビン
デーモン
管理者
11/10 11:0 ...
同期
シャットダウン
停止する
郵便
オペレーター
ゲーム
アルヴィン
梁旭
...

次の例では、スペースを区切り文字として使用して、content.txt ファイルの最初のフィールドを出力します。

$ カット -d " " -f 1 コンテンツ.txt 
ウブントゥ
マイクロソフト
オキシ
ユニックス
フリーBSD

以下の例では、複数のフィールドを抽出します。ここでは、コロン (:) 区切り文字を使用して、ファイル /etc/passwd 内の文字列 /bin/bash を含む行から最初のフィールドと 6 番目のフィールドを抽出します。

$ grep "/bin/bash" /etc/passwd | cut -d':' -f1,6
ルート:/ルート
アルビン:/home/アルビン

フィールドの範囲を表示するには、次に示すように、開始フィールドと終了フィールドをハイフン (-) で区切って指定します。

$ grep "/bin/bash" /etc/passwd | cut -d':' -f1-4,6,7
ルート:x:0:0:/root:/bin/bash
アルビン:x:1000:1000:/home/アルビン:/bin/bash

選択した出力を完了する方法

選択した出力フィールドを完了する(つまり、選択を解除する)には、 --complementオプションを使用します。このオプションは、指定されたフィールドを除くすべてのフィールドを出力します。

次の例では、/etc/passwd ファイル内の /bin/bash を含む行の 2 番目のフィールドを除くすべてのフィールドを出力します。

$ grep "/bin/bash" /etc/passwd | cut -d':' --complement -f2
ルート:0:0:ルート:/ルート:/bin/bash

出力区切り文字の指定方法

出力区切り文字を指定するには--output-delimiterを使用します。入力区切り文字は-dで指定され、出力区切り文字はデフォルトで入力区切り文字と同じになります。

まず、次の例を使用して、出力区切り文字が指定されていない場合の出力をテストしてみましょう。

$ カット -d: -f1,7 /etc/passwd | ソート | ユニーク -u
_apt:/usr/sbin/nologin
バックアップ:/usr/sbin/nologin
bin:/usr/sbin/nologin
デーモン:/usr/sbin/nologin
dnsmasq:/usr/sbin/nologin
ゲーム:/usr/sbin/nologin
ブヨ:/usr/sbin/nologin
irc:/usr/sbin/nologin
ランドスケープ:/usr/sbin/nologin
リスト:/usr/sbin/nologin
lp:/usr/sbin/nologin
lxd:/bin/false

ここで、出力区切り文字をスペースとして指定する--output-delimiterオプションを追加します。

$ cut -d: -f1,7 --output-delimiter ' ' /etc/passwd | sort | uniq -u
_apt /usr/sbin/nologin
/usr/sbin/nologin をバックアップする
bin /usr/sbin/nologin
デーモン /usr/sbin/nologin
dnsmasq /usr/sbin/nologin
ゲーム /usr/sbin/nologin
ブヨ /usr/sbin/nologin
irc /usr/sbin/nologin
ランドスケープ /usr/sbin/nologin
/usr/sbin/nologin をリストする
lp /usr/sbin/nologin
lxd /bin/false

別の例をテストして、セパレーターを使用して 1 行に 1 つのフィールドを印刷してみましょう。

改行を示すために--output-delimiter $'\n'として指定します。

出力は次のようになります。

$ grep root /etc/passwd | cut -d':' -f1,6,7 --output-delimiter=$'\n'

/根
バイナリ
オペレーター
/根
/sbin/ノーログイン

コンテンツを文字として抽出する方法

-cオプションを使用すると、文字の位置に基づいて抽出できます。スペースとTabも文字として扱われることに注意してください。

次のように、context.txt ファイルの各行の最初の文字を出力します。

$ カット -c 1 コンテンツ.txt
あなた
ま
お
あなた
ふ

以下は、context.txt ファイルの各行の最初の 7 文字を示しています。

$ カット -c 1-7 コンテンツ.txt
ウブントゥ
マイクロソ
XOt
ユニックス
フリーBSD

開始位置または終了位置のみを指定してもう一度テストしてみましょう。

以下は最後から 2 番目の文字を抽出します。

$ カット -c2- コンテンツ.txt
Ubuntu Linux
マイクロソフトウィンドウズ
sXエルキャピタン
ニックス
リーBSD

最初の文字から 4 番目の文字を抽出します。

カット -c-4 content.txt
ウブン
マイクロ
オキシ
ユニックス
無料

バイト単位で抽出する方法

-bオプションを使用して、バイト位置を指定したり、指定した各位置をコンマで区切ったり、 -を使用して範囲を指定したりして、行の一部を選択します。

次の例では、content.txt ファイルの各行の 1 番目、2 番目、3 番目のバイトを抽出します。

$ カット -b 1,2,3 コンテンツ.txt 
ウブ
マイク
オキシ
ユニ
フリー

次のコマンドを使用して範囲を一覧表示することもできます。

$ カット -b 1-3,5-7 コンテンツ.txt 
ウブツ 
ミコソ
翻訳 
ユニ
フリーBSD

いくつかの実例

cut は、他の Linux または Unix コマンドと組み合わせて使用​​されることが多い便利なコマンドです。

たとえば、ps コマンドから USER、PID、COMMAND を抽出する場合は、次のようにします。

ps -L un | tr -s " " | cut -d " " -f 2,3,14-
ユーザーPIDコマンド
0 676 /sbin/agetty -o -p --\u --keep-baud 115200,38400,9600 ttyS0 vt220
0 681 /sbin/agetty -o -p --\u --noclear tty1 linux
0 23174 -バッシュ
0 26737 ps -L un
0 26738 tr -s
0 26739 カット -d -f 2,3,14-

メモリの合計値、使用値、空き値を抽出し、ファイルに保存する別の例をテストしてみましょう。

$ free -m | tr -s ' ' | sed '/^Mem/!d' | cut -d" " -f2-4 >> memory.txt
$ 猫メモリ.txt
985 86 234

要約する

cut コマンドは、パイプを介して他の多くの Linux または Unix コマンドに接続できます。追加のテキスト処理のために、1 つ以上のフィルターをパイプで渡すことができます。

cut コマンドの制限の 1 つは、区切り文字として複数の文字を指定できないことです。複数のスペースは複数のフィールド区切り文字としてカウントされるため、目的の出力を得るには、cut コマンドの前に tr コマンドを使用する必要があります。

Linux の cut コマンドの詳細な説明については、これで終わりです。Linux の cut コマンドに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Linux gzipコマンドの使用
  • Linux userdel コマンドの使用法
  • Linuxのdateコマンドの使用
  • Linuxコマンドをバックグラウンドで実行する方法
  • Linux statコマンドの使用
  • Linux lsコマンドの使用
  • Linux lnコマンドの使用
  • Linux bzip2 コマンドの使用

<<:  Vueのvue-tree-colorコンポーネントの組織構造図の事例を詳しく解説

>>:  MySQL インデックスクエリ最適化スキルを習得するための記事

推薦する

JSON.stringify のさまざまな用途のまとめ

序文json を使用したことがある人なら、オブジェクトを文字列化してからバックエンドに送信するのが一...

js はマウスによる画像の切り替えを実装します (タイマーなし)

この記事の例では、マウス切り替え画像を実現するためのjsの具体的なコードを参考までに共有しています。...

Tomcat 例外の解決方法 (リクエスト ターゲットに無効な文字が見つかりました。有効な文字は RFC 7230 および RFC 3986 で定義されています)

1. シナリオ表示Tomcat ログに次の例外情報が時々報告されます。何が起こっているのでしょうか...

Docker ケース分析: MySQL データベース サービスの構築

目次1 設定ディレクトリとデータディレクトリを作成する3 イメージからホストに構成ファイルをコピーす...

jquery+springbootでファイルアップロード機能を実現

この記事の例では、ファイルアップロード機能を実現するためのjquery+springbootの具体的...

MySQL コマンドを使用してインデックスを作成、削除、およびクエリする方法の紹介

MySQL データベース テーブルでは、インデックスを作成、表示、再構築、削除できるため、クエリ速度...

Vue3 における provide と inject の使用法と原則

序文:親コンポーネントと子コンポーネント間でデータを渡す場合、通常は props と emittin...

Nginx gzip設定について

nginx がリソース圧縮を実現する原理は、ngx_http_gzip_module モジュールを介...

Vueは透かし効果を簡単に実現します

序文: Vueプロジェクトで透かし効果を使用するには、コンテナを指定できます効果画像: 1. コンテ...

vue 動的コンポーネント

目次1. コンポーネント2. キープアライブ2.1 問題点2.2 キープアライブを使って解決する2....

JSはプログレスバーをドラッグして要素の透明度を変更することを実装しています

今日ご紹介したいのは、ネイティブ JS を使用してプログレス バーをドラッグし、要素の透明度を変更す...

Zabbixを使用してMySQLを監視する方法

Zabbix 導入ドキュメントzabbix導入後zabbixエージェントの操作1. MySQLを監視...

MySQL の count 関数の正しい使い方の詳細な説明

1. 説明MySQLでは、テーブル内の行の総数を取得する必要がある場合、通常は次の文を使用します。 ...

Linuxサーバーのディスク容量を拡張する方法

目次序文ステップ序文今日、es ログが記録されていないことに気付きました。filebeat、elas...