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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

1回答

6104閲覧

CSVデータの読み込み

chintao1224

総合スコア155

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

1クリップ

投稿2017/02/05 06:45

CSVデータを正常に読み込みたいです。

サイトを見て書いたコードがあるんですが、そのコードでは歯抜けのCSVデータが詰まって読み込まれてしまいます。

正常に読み込めるCSVデータ
a,b,c,d,e,f

正常に読み込めないデータ(歯抜けのデータ)
a,,c,,,f

この場合詰まって読み込まれてa,c,fが配列に入ります。

java

1 String line; 2 StringTokenizer token; 3 while ((line = buffer.readLine()) != null) { 4 row++; 5 byte[] b = line.getBytes(); 6 line = new String(b, "UTF-8"); 7 8 //区切り文字","で分割する 9 token = new StringTokenizer(line, ","); 10 11 String data[] = new String[34]; 12 13 int i = 0; 14 15 data[0] = String.valueOf(row); 16 i++; 17 18 //分割した文字を格納する 19 while (token.hasMoreTokens()) { 20 String str = token.nextToken().toString().replace("\"", ""); 21 if (str == null) { 22 str = ""; 23 } 24 data[i] = str.replace("'", "''"); 25 i++; 26 } 27 data[31] = userid; 28 data[32] = null; 29 data[33] = null; 30 }

どうすれば正常に読み込めるのでしょうか。

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

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

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

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

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

guest

回答1

0

ベストアンサー

String::split関数でlimit=-1を指定することで、いわゆる「歯抜け」も空文字として取得できます。

Java

1String s = "a,,c,,,f"; 2String[] list = s.split("," , -1); 3for (int i = 0 ; i < list.length ; i++){ 4 System.out.println("[" + list[i] + "]"); 5}

参考:JavaのString.split(”,”)は、split(”,”, -1)にしたほうがいい

投稿2017/02/05 07:01

can110

総合スコア38266

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

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

chintao1224

2017/02/05 07:20

僕はtoken = new StringTokenizer(line, ",");を使っているんですが、String[] list = s.split("," , -1);に入れ替えたほうが良いのでしょうか。
chintao1224

2017/02/25 10:32

遅くなってすみません。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問