No.2ベストアンサー
- 回答日時:
以前作成した1行文字列をフィールド分割する関数ソースを載せておくので
参考にしてください。
もっといい方法があるのかもしれませんが、とりあえずここでは
一文字ずつ呼んでダブルクオートを削除し、又ダブルクオート内の
カンマはそのまま文字として使用するようにしてます。
面倒だったので文字内にダブルクオートを使用することは考慮に入れてません(^^;
ArrayList parsLine(String line){
ArrayList fields = new ArrayList();
if(line == null) return;
boolean isQuort = false; //ダブルコーテーション内フラグ
StringBuffer field = null;
for(int i=0;i<line.length();i++){
char code = line.charAt(i);
if(isQuort){
//ダブルクオート内
if(code == '\"'){
isQuort = false;
}
else{
if(field == null) field = new StringBuffer();
field.append(code);
}
}
else{
//ダブルクオート外
if(code == '\"'){
isQuort = true;
}
else if(code == ','){
if(field == null) field = new StringBuffer();
fields.add(field.toString());
field = null;
}
else{
if(field == null) field = new StringBuffer();
field.append(code);
}
}
}
if(field != null){
fields.add(field.toString());
}
return fields;
}
No.4
- 回答日時:
基本的には#3のkana-tanさんの方法でうまくいくと思うのですが,".." の中に ',' を含むような複雑な文字列を処理したい場合は,java.io.StreamTokenizer クラスを利用すると良いと思います。
このクラスには,quoteChar(int ch) というメソッドがあって,ch で指定した文字を引用符として解釈してくれます。この指定をしたあと,java.io.StreamTokenizer#nextToken() を使って次のトークンを読み込むと,<ch で指定した文字>の直後から,次に<ch で指定した文字>が現れる直前までを一つの文字列として読み込むことができます。
参考URL:http://java.sun.com/j2se/1.3/ja/docs/ja/api/java …
No.3
- 回答日時:
StringTokenizerクラスのコンストラクタの引数には、区切り文字を指定できます。
次のような、感じです。
(ソース中に"(ダブルクォート)を書いたので見にくくなってすみません)
String str = "\"This\",\"is\",\"a\",\"test\"";
StringTokenizer st = new StringTokenizer(str,"\",");
while(st.hasMoreTokens()){
System.out.println(st.nextToken());
}
結果は
This
is
a
test
と表示されます。
(APIドキュメントのStringTokenizerクラスの説明に記載されているソースを一部改変しました)
No.1
- 回答日時:
一般的かどうかはわかりませんが、
私の場合は jakartaのOROライブラリ(正規表現ライブラリ)
を使って置換しています。
Perlと同じようにsコマンドで置換できます。
outStr = perl.substitute("s/\"//g", inStr);
みたいな感じ。
正規表現ライブラリの使い方については
JavaWorld 2001/4月号にも載っています。
参考URL:http://jakarta.apache.org/oro/index.html
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Google Drive スプレッドシートでCSV出力をすると、""が付く値と付かない値があります。解決策を教えてください。 1 2022/04/09 23:43
- Java javaのCSVデータ読込についてです 6 2022/07/02 10:58
- Excel(エクセル) PowerQueryに詳しい方教えてください(Office365) 1 2022/07/24 21:11
- Excel(エクセル) CSVファイルがカンマ区切りにならない。対処法を教えていただきたいです。 仕事でSMS一斉送信ができ 2 2022/07/01 21:24
- Visual Basic(VBA) VBA 毎日取得するデータを順番に反映していく方法 6 2023/08/26 16:22
- Visual Basic(VBA) vba 等間隔の列に対しての計算 6 2022/05/17 20:15
- Access(アクセス) CSVファイルの「0落ち」にVBA 6 2023/02/02 15:27
- Visual Basic(VBA) エクセルVBA 3 2022/06/23 20:00
- その他(プログラミング・Web制作) python 気象データの取得 2 2023/06/20 23:54
- JavaScript javascriptで文字分割は、 split() などメソッド不要??? 4 2023/02/06 22:50
このQ&Aを見た人はこんなQ&Aも見ています
-
「環境が人を育てる」って本当?環境によって人格や生き方は本当に変わるのか
環境が人生に与える影響は実際どれほどのものなのか、専門家の田宮由美さんに伺った。
-
javaのCSVデータ読込についてです
Java
-
カンマ区切りのCSVファイルから"を削除したい
その他(プログラミング・Web制作)
-
ダブルクォーテーションのreplaceの方法
JavaScript
-
-
4
ダブルクォーテーションの削除(置換)
Perl
-
5
count(*)で取得した値をJAVAの変数に代入するには?
Java
-
6
Excelでcsvやtxtで保存する時にダブルクォートが勝手に付く
Excel(エクセル)
-
7
Path型をString型へ変換する(Java)
Java
-
8
csvファイルを2次元配列に格納
Java
-
9
フォーム上で押されたボタンによってサーブレットの処理を変えたい
Java
-
10
JAVAにのeclipseに関する質問です! 私は最近eclipseをインストールしたのですが、最初
Java
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「タイプ初期化子が例外をスロ...
-
数字か文字列かを判定する関数
-
時間の取得
-
VBA Evaluate関数 型が一致しま...
-
連続する「\\」をひとつの「\\...
-
文字列からダブルクオートの削除
-
VB.Net Object型 空かどうか
-
nullで、return出来るのはどん...
-
全角スペースのチェックについて
-
0除算の例外処理ができない!!...
-
[C#][FX]DLLを利用した共有メモ...
-
Excelでのエラー
-
例外ってIf文の中に入れますか...
-
Javaで文字列をゼロ埋め(ゼロパ...
-
C#の捕捉されない例外処理の対...
-
Java main関数内でStatic変数使...
-
WebClient()以外でネットにアク...
-
javaプログラムで背景色を変更...
-
変数名の付け方
-
インスタンス参照でアクセスで...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「タイプ初期化子が例外をスロ...
-
VB.Net Object型 空かどうか
-
Timestamp型への変換について(J...
-
連続する「\\」をひとつの「\\...
-
全角スペースのチェックについて
-
VB.NETで16進数が正しいかどう...
-
C# マルチスレッドにおける例外...
-
文字列からダブルクオートの削除
-
VBA Evaluate関数 型が一致しま...
-
C#の捕捉されない例外処理の対...
-
例外ってIf文の中に入れますか...
-
時間の取得
-
【JAVA】与えられた金額を貨幣...
-
nullで、return出来るのはどん...
-
String型の日付(2005/11/25)の...
-
サーブレットからJSPの呼び出し...
-
0除算の例外処理ができない!!...
-
文字列が数字のみで構成されて...
-
VBA 400エラー 1004エラー
-
数字か文字列かを判定する関数
おすすめ情報