Bashシェルスクリプトで1〜100までの数からランダムに10個を重複なしで取り出す方法
はじめに
テストデータの中からランダムにデータを n件 (例えば10件)、取り出そうと思いました。
ランダムに抽出する方法を紹介します。
検証環境
$RANDOM
環境変数を使った方法
$RANDOM
環境変数を使う方法が思いつきましたが、問題がありました。
上記方法では、1から100までのランダムな値が取得はできますが、同じものが取得されることがあります。 ( ex: 1 99 3 53 1 5 20 19 80 100
で、 1 が重複している )
同じデータを重複して取得しないようにするにはどうしたらよいでしょう?
shuf
コマンドとパイプを使った方法
以下のワンライナーで実現できます。
- データを用意(ここでは1〜100にしています。)
shuf
コマンドでデータ全体をシャッフル(行の順番を入れ替えるコマンドです)- 最初の10件を取得
head
コマンドを使わない方法もあります。shuf
コマンドには -n
オプションがあります。
これを使うとシャッフルした結果のうち、数件のみを出力させることができます。
shuf
コマンドのみを使った方法
shuf
コマンドだけでもっとシンプルに実現する方法があります。
shuf
コマンドには、「ランダムに出力する数値の範囲」を -i
オプションで指定できます。
shuf -i
を使う場合、シャッフルする連続する数値の範囲を任意に指定できます。
例えば 10から15までの数値をシャッフルして出力 するには以下のようなコマンドを実行します。
ひとこと
実際にはテストデータファイル data.txt からデータをピックアップする必要があったため、以下のような使い方をしました。
そこそこ便利です。
ディスカッション
コメント一覧
まだ、コメントがありません