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で質問しましょう!
似たような質問が見つかりました
- UNIX・Linux Linuxについて質問です。 以下のような設定をしたMakefileを作成するにはどう記述すればよい 1 2023/02/03 20:10
- その他(プログラミング・Web制作) Fortranでの出力ファイル 2 2023/03/21 21:25
- その他(プログラミング・Web制作) google formsを使ったタスク依頼フォーム作成におけるご相談 1 2023/06/22 15:55
- Visual Basic(VBA) このVBAでExcelアプリケーションを作成は必要ですか? 3 2023/07/19 21:13
- その他(プログラミング・Web制作) pandasでまとめてインデックスを削除するにはどうすればいいですか? たとえば、以下のプログラムで 1 2022/07/31 23:09
- UNIX・Linux サーバー間のデータコピー(データ形式とデーターフォーマットの変換あり。一定間隔で処理) 2 2023/08/22 22:15
- Visual Basic(VBA) vbaのエラー対応(実行時エラー7:メモリが不足しています) 4 2023/04/24 00:20
- Visual Basic(VBA) エクセルVBA(実行時エラー438)の対処法を教えてもらえないでしょうか 3 2023/04/22 13:43
- Visual Basic(VBA) 【VBA】写真の縦横比を変えずに貼り付ける 5 2023/06/13 11:42
- Visual Basic(VBA) Excel-VBAでのファイルの開き方 4 2023/02/14 11:01
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
SQLファイルの読み込み
-
Excelマクロ 空白セルを無視し...
-
【ExcelVBA】300万件越えCSVか...
-
VBAで複数のCSVからレコードセ...
-
ダブルコーテーション付きでCSV...
-
バッチ処理 特定の文字以降を...
-
VBAでcsvファイルもシートもあ...
-
Fortran:列数の分からないデー...
-
StringGridの中身をCSV形式で保...
-
ファイル名を変数で書きこむfwr...
-
Sikulix2.0.5(Jython2.7.3)でcs...
-
エクセルの任意のシートをcs...
-
VBA テキストボックスを選択状...
-
シート内容の文字列を置換してV...
-
EXCEL→CSV保存時のダブルクォー...
-
pythonでリストをCSVに出力する...
-
[コンパイルエラー 修飾子が不...
-
VBAで文字列を引数とするアドイ...
-
FileListBoxで出すものを絞り込...
-
LibreOffice Calcのマクロで、...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
SQLファイルの読み込み
-
Rubyでバイナリファイルを編集...
-
C# ファイルを読み込みlistvie...
-
サーバにアップしたファイルを...
-
C# ファイルパスを格納した配列...
-
【ruby】zipファイルデータをST...
-
Excelマクロ 空白セルを無視し...
-
バッチ処理 特定の文字以降を...
-
【ExcelVBA】300万件越えCSVか...
-
ダブルコーテーション付きでCSV...
-
VBAでcsvファイルもシートもあ...
-
パイソンでテキストファイルが...
-
VBA テキストボックスを選択状...
-
CSVで余計な空行が入る
-
EXCEL→CSV保存時のダブルクォー...
-
INPUTタグ disabledの文字色を...
-
teratermで、ファイル名をinput...
-
SQLでテキストボックスの文字を...
-
MS-DOSバッチファイルコマンド...
-
Access VBA エラー2448について
おすすめ情報