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

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

新規登録して質問してみよう
ただいま回答率
85.35%
CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

Q&A

解決済

1回答

4220閲覧

csvファイルのデータに改行コードがある場合の読み込みについて

icecloud

総合スコア3

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

0グッド

0クリップ

投稿2021/10/14 04:47

シェルスクリプトを用いて改行コードを含むデータがあるcsvファイルを1行ずつ読み込みたいと考えています。

index.csv A,B,C(改行)D,E F,G,H(改行),I,J

上記のようなデータがある場合に、各行の4列目を取得する時、改行が区切り文字?として認識されてしまいうまく抽出できません。

sh

1cat index.csv | while read line 2do 3 INDEX=`echo "$line" | cut -d, -f4` 4 echo "$INDEX" 5done

欲しい出力としては、以下ですが、このようになりません。

D I

どのようにすれば良いでしょうか。

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2021/10/14 06:48

KojiDoi さんの回答のコメントにあなたが書いた、 > データは以下のようになっています。説明不足でした。申し訳ありません。 > "A","B","C(改行)D","E" > "F","G","H(改行)I","J" ・・・は質問欄を編集して追加情報として追記してください。 sh って何ですか? CSV パーサーのライブラリは使えないのですか? 改行コードやデリミタがフィールド値の中にある場合、フィールド値をダブルクォート (") で囲むと言った約束を設けて対応しますが、そのような CSV ファイルの処置が可能なパーサーを自力で作るのは簡単ではありません。
guest

回答1

0

ベストアンサー

データの中に入り込んでいる改行と、レコードの区切りの改行。
この二つを区別するための基準が必要です。たとえばデータの中の改行は直前にバックスラッシュなどのエスケープ文字が必ず入っているとか、当該要素は引用符で囲まれているとかです。

質問を読む限りでは、そうした条件が満たされていないようですので、言われているような対処は実現不能と判断せざるを得ないでしょう。

投稿2021/10/14 05:01

KojiDoi

総合スコア13692

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

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

icecloud

2021/10/14 05:16

データは以下のようになっています。説明不足でした。申し訳ありません。 "A","B","C(改行)D","E" "F","G","H(改行)I","J"
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問