
CSVファイルの処理で困っています。
ファイルから1行読んだ後、必要なカラムだけを
取得しようと思っています。
TStrings と DelimitedText を使って
カンマで分割してくれるのは便利なのですが、
どうも半角スペースでも分割してしまうようです。
Delimiterプロパティで ',' と指定してるはず
なのですが、空白も強制的に分割文字になって
しまうんでしょうか?
ソースのイメージとしては
Var SL: Tstrings;
で宣言して
begin
・・・
readln(target, line); { 1行読み込み }
SL := TStringList.Create;
SL.Delimiter := ',';
SL.DelimitedText := line;
とやった上で
SL[0]とかSL[1]とかで必要なカラムを取得しています。
宜しくお願いします。
No.2ベストアンサー
- 回答日時:
こんにちは、honiyonです。
お礼ありがとうございます(..
なるほど、CSV側が自動生成では、それに修正加えろ、というのは難しいかも知れませんね...(笑)
では、やはりCommaTextに代わるものを自分で作成する必要があると思います。
下記は何のエラーも想定していない基本的な独自処理のサンプルです。
メモ帳で適当に書いた非テストコードなので、あくまで考え方の参考程度にお願いします(^^;
また、半角カンマを含む文字列の処理は想定していませんのでご注意ください。
procedure SetCSV(var SL:TStringList; line:string);
var
i : integer;
ans : string;
begin
i := 0;
repeat
if line[i] = ',' then begin //カンマ文字発見
SL.Add(ans);
ans := '';
end else begin //カンマ以外
ans := ans + line[i];
end;
inc(i);
until (length(line) < i);
end;
このコードは、
readln(target, line); { 1行読み込み }
SL := TStringList.Create;
SetCSV(SL,line);
こんな風に使用します。
参考になれば幸いです(..
ありがとうございました。
サンプルを参考に自作のコードを作ってみました。
何とか解決ができたようです。
いろいろありがとうございました。
No.3
- 回答日時:
TStringsじゃないですが・・・
拙作、StrToken.pasのPickTokenメソッドならば、スペースを気にせず切り出しが出来ると思います。
String型変数に読み込みたいデータを入れて、それを第一引数に、第二引数に,を指定します。
実行すると、切り出された最初のトークンが戻り値として返り、引数に指定したString型変数の中身が、トークン切り出し後の残り文字列になります。
詳しくは添付サンプルファイルをご覧ください。
下記ページのリンクよりダウンロードできます。
参考URL:http://takamichie.at.infoseek.co.jp/warehouse/un …
ありがとうございました。
サンプルを参考に自作のコードを作ってみました。
何とか解決ができたようです。
いろいろありがとうございました。
Delphiの世界もいろいろサンプルコードがあるんですね。
何となく親切な人が多いジャンルだなぁと感じました。
自分も他の人の役に立てるように頑張ります!
No.1
- 回答日時:
こんにちは、honiyonです。
文字列が " "で文字が囲まれていれば、正しく処理されます。取り扱おうとしているCSVには、文字列が " で囲まれていないのですね。一応CSVの規定としては、文字列は " "で囲むように指示されています。
ということでCSVに " "を付加すれば解決する問題ですが、それをせずに処理するには、一時的に他の文字に置き換えるか、独自でCSV処理するしかないと思います。
因みにカンマ区切りであれば、
SL.CommaText := line;
で OK です。 Delimiterは、カンマ以外で区切られているケースに対応する場合のみ使用するようにすると、ソースがちょっぴりスッキリするかもです。
参考になれば幸いです(..
ご回答ありがとうございました。
そうなんです。文字列が " " で囲われていない
ファイルを操作しようとしているんです。
確かに、honiyon さんがおっしゃるとおり、
文字列が囲われていて、カンマ区切りであれば
SL.CommaText := line;
で済むんですが、そのCSVファイルはとある社内システムから
毎日自動的に生成されてくるので、それを変えるのは困難です。
何か良い方法はありませんか?
もしくはサンプルソースなどがあると嬉しいです。
宜しくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- FX・外国為替取引 MT4のSL・TP設定 1 2023/07/09 12:21
- その他(ゲーム) ファミコンの「コズミックウォーズ」のような、PCゲーム(steam)を探しています 1 2023/04/03 19:45
- 電車・路線・地下鉄 武豊線のキハ58はいつ頃まで使われていたのですか?。 1 2022/09/20 18:24
- 貨物自動車・業務用車両 エンジンオイルの扱いについて 4 2023/05/23 06:56
- C言語・C++・C# pythonのファイルの並びでの読み込みとリストについて 4 2022/04/13 03:52
- 国産車 エンジンオイルの購入先 5 2022/12/31 11:48
- FX・外国為替取引 pine scriptのコードが動作しない 1 2023/02/01 19:03
- 特撮 ヒカリアンは何故新幹線が正義で、SLが悪役なのでしょうか? 1 2022/11/13 11:24
- 文学・小説 「SLの運転手、整備士が機関車ごと戦国時代にタイムスリップし、信長や他の武将達が蒸気機関を狙って戦い 14 2022/11/25 09:18
- 電車・路線・地下鉄 SLやまぐち 乗りたいし、見たい どうすれば 8 2022/05/02 15:04
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
CSVファイルの中で、「 , 」カ...
-
エクセルで数値を全角文字(カ...
-
CSVの定義
-
Excelについて質問です。 セル...
-
openoffice calcで#DIV/0! の...
-
C#で、テキストボックスの入力...
-
WORDで改ページすると時々グレ...
-
EXCELからCSVにすると余計なカ...
-
【VBA】エクセルで値のみクリッ...
-
カンマ区切りでないテキストをc...
-
パス区切りの文字について
-
StringGridの内容をクリップボ...
-
マクロを使ってフォルダー内に...
-
JPY ¥1,500.00は日本円でお幾ら?
-
カンマ区切り
-
データにカンマが入ったCSVデー...
-
メモ帳からエクセルにセル区切...
-
3桁ごと?4桁ごと?コンマの...
-
データグリッド内の数値をカン...
-
VBAでtxtファイルを読み込む際...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
CSVファイルの中で、「 , 」カ...
-
エクセルで数値を全角文字(カ...
-
マクロを使ってフォルダー内に...
-
EXCELからCSVにすると余計なカ...
-
Excelについて質問です。 セル...
-
CSVの定義
-
[VBA][Excel]クリップボードか...
-
WORDで改ページすると時々グレ...
-
カンマ区切りの数字をCSVフ...
-
C#で、テキストボックスの入力...
-
データにカンマが入ったCSVデー...
-
VBAでtxtファイルを読み込む際...
-
カンマ区切り
-
VB2005のTextBoxでカン...
-
メモ帳からエクセルにセル区切...
-
JPY ¥1,500.00は日本円でお幾ら?
-
テキストファイルからReadLine...
-
カンマ区切りでないテキストをc...
-
エクセルにペーストする際にカ...
-
パス区切りの文字について
おすすめ情報