awk初心者です。
あるファイル(targetファイル)に、どのような属性があるのかを検索ファイル(objectファイル)を
使って調べたいのです。そこでawkを使って:
targetファイル
5
a
c
objectファイル
1,aa
2,bb
3,cc
4,dd
5,aa
6,bb
7,cc
8,dd
9,aa
10,bb
a,cc
b,dd
c,aa
d,bb
e,cc
f,dd
g,aa
h,bb
i,cc
j,dd
以下のようなスクリプトを作成し
mawk32 -f スクリプト target.txt object.txt
としたのですが、動作しません。
何らかの御助言を頂ければ幸いです。
#targetファイル読み込み
FILENAME == ARGV[1]{
dat1[FNR]=$1
no_dat1 = FNR
}
#objectファイル読み込み
FILENAME == ARGV[2]{
dat2[FNR]=$0
no_dat2 = FNR
}
#相互に検索
END{
for (i = 1; i <= no_dat1; i++){
for (j = 1; j <= no_dat2; j++){
if (dat1[i]~/dat2[j]/) { print dat1[i],dat2[j] }
}}}
No.1ベストアンサー
- 回答日時:
$ awk -f select.awk target.txt object.txt
5 2,aa
a 2,cc
c 2,aa
この↑結果がほしいのかな?
[select.awk]
BEGIN {
FS=","
}
#targetファイル読み込み
FILENAME == ARGV[1]{
tgt[FNR]=$1
no_tgt = FNR
}
#objectファイル読み込み
FILENAME == ARGV[2]{
obj1[FNR]=$1
obj2[FNR]=$2
no_obj = FNR
}
#相互に検索
END{
for (i = 1; i <= no_tgt; i++){
for (j = 1; j <= no_obj; j++){
if (tgt[i] == obj1[j]) { print tgt[i],obj1[2]","obj2[j] }
}}}
それとも、こっち↓?
$ awk -f select.awk target.txt object.txt
5 5,aa
a 1,aa
a 5,aa
a 9,aa
a a,cc
a c,aa
a g,aa
c 3,cc
c 7,cc
c a,cc
c c,aa
c e,cc
c i,cc
これなら、元のコードの
if (dat1[i]~/dat2[j]/) { print dat1[i],dat2[j] }
を
if (dat2[j] ~ dat1[i]) { print dat1[i],dat2[j] }
にかえればできるよ。
そうか、データ構造をきちんと把握した上で読み込み、==で対応させれば良いのですね。
ありがとうございました!大変勉強になりました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
プログラミングについて プログ...
-
プログラミングの進学について
-
Web初心者です。 簡易的なWebペ...
-
vba クリップボードクリアにつ...
-
pythonでAmazonのほしいものリ...
-
プログラマーは誘惑にさらされ...
-
Google Colabでimport soxが出...
-
Google ColaboでGUI作成
-
ExcelVBAでFormulaR1C1を列範囲...
-
HTMLソースが表示のページのも...
-
VBAでパワーシェルを実行したい...
-
Pythonで指定時間までスリープ...
-
近年誕生したプログラミング言語
-
Python... 環境設定 初心者です...
-
chatGPTで次々と質問をしていく...
-
このURLで広告を出しているのは...
-
テキストファイルの1行目のみを...
-
ITパスポートの勉強をしていま...
-
初心者powershellのPS1ファイル...
-
python エラー
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
SQLファイルの読み込み
-
ファイルサイズ
-
【ruby】zipファイルデータをST...
-
C# ファイルを読み込みlistvie...
-
ファイルの文字コード
-
バッチ処理 特定の文字以降を...
-
VBAでcsvファイルもシートもあ...
-
Excelマクロ 空白セルを無視し...
-
ダブルコーテーション付きでCSV...
-
【ExcelVBA】300万件越えCSVか...
-
ファイル名を変数で書きこむfwr...
-
VBA テキストボックスを選択状...
-
[コンパイルエラー 修飾子が不...
-
fortranでNAのあるデータを読み...
-
複数のファイルをまたぐエクセ...
-
teratermで、ファイル名をinput...
-
VB.netでShellExecuteがしたい
-
VBAで複数のCSVからレコードセ...
-
Fortran:列数の分からないデー...
-
CSVで余計な空行が入る
おすすめ情報