質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
シェルスクリプト

シェルスクリプトは、UNIX系のOSもしくはコマンドラインインタプリタ向けに記述されたスクリプト。bash/zshといったシェルによって実行されるため、このように呼ばれています。バッチ処理などに使用されており、テキストファイルに書かれた命令を順に実行します。

Q&A

解決済

2回答

405閲覧

catとawkを使って、入力ファイルの情報を利用して出力ファイル名を決定して入力ファイルを編集する方法

grandchild

総合スコア10

シェルスクリプト

シェルスクリプトは、UNIX系のOSもしくはコマンドラインインタプリタ向けに記述されたスクリプト。bash/zshといったシェルによって実行されるため、このように呼ばれています。バッチ処理などに使用されており、テキストファイルに書かれた命令を順に実行します。

0グッド

0クリップ

投稿2022/02/14 11:51

下記のようなことをしたいのですが、シェルスクリプトでファイルを読み込む際の1列目2列目3列目の情報をファイル名として4列目を出力したいのですが、可能でしょうか?

<入力ファイル> a.csv
2010 12 27 340.
2010 11 16 271.
....
2012 3 11 120.

<シェルスクリプト>
cat a.csv | awk '(printf $4)' > $1$2$3.csv

<出力ファイル> 20101106.csv
271.
...

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

こっちがかんたんかな

sh

1cat a.csv | \ 2while read a b c d 3do 4 echo $d >"$a$b$c".csv 5done

投稿2022/02/14 12:00

takasima20

総合スコア7458

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

grandchild

2022/02/14 12:22

ありがとうございました。とても参考になりました。
melian

2022/02/14 12:55 編集

今回の場合は CSV なのと一桁の日・月があるので、 cat a.csv | \ while IFS=, read -r a b c d do echo "$d" > $(printf '%04d%02d%02d.csv' $a $b $c) done とするとよいのではないかと。
takasima20

2022/02/14 13:01

そうですね。ありがとうございます。
guest

0

ベストアンサー

bash

1$ awk -F, '{print $4 > sprintf("%04d%02d%02d.csv", $1, $2, $3)}' a.csv 2$ cat 20101116.csv 3271. 4$ cat 20101227.csv 5340. 6$ cat 20120311.csv 7120.

投稿2022/02/14 12:00

melian

総合スコア19712

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

grandchild

2022/02/14 12:12

自分のしたいことにマッチしていました。awkってこんなことができるんですね。melianさん、本当にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問