よろしくお願い致します。
エクセルで編集したCSVファイルを読み込み、HTMLとして表示するCGIがあります。
エクセルでCSVファイルを編集すると最後の項目の後にカンマ(,)が付かないのですが、
使用しているCGIでは、カンマがないと行が改行されたとみなされません。
行の最後にカンマがなくても行を改行させるには、どのようなコードを追加すればよいのでしょうか?
CGIのCSVファイルの読み込みする部分のコードは以下のようになっています。
# ログファイル読み込み
my $LOG_FILE = 'log.csv';
my $io = IO::File->new($LOG_FILE, 'r') or die $!;
flock($io, 1);
while(my $line = $io->getline) {
push @ids, (split(/,/, $line))[0];
push @new_checks, (split(/,/, $line))[1];
push @dates, (split(/,/, $line))[2];
push @contents, (split(/,/, $line))[3];
push @contents2, (split(/,/, $line))[4];
push @contents3, (split(/,/, $line))[5];
push @contents4, (split(/,/, $line))[6];
push @contents5, (split(/,/, $line))[7];
push @contents6, (split(/,/, $line))[8];
}
分かりにくい説明で申し訳ありません。
補足説明も致しますので、どうぞよろしくお願い致します。
No.2ベストアンサー
- 回答日時:
逆の発想ですが、行の末尾にカンマを付けてはどうでしょうか。
...
while(my $line = $io->getline) {
$line .= ',' if substr($line, -1) ne ',';
push @ids, (split(/,/, $line))[0];
...
お礼が遅くなり誠に申し訳ありませんでした。
お教え頂いた通りにコードを加えてみたところ、
1行目と2行目を区別して表示することができました。
本当に助かりました。ありがとうございました。
No.3
- 回答日時:
項目名が違う(項目1<->項目6)ので、別項目のように思えてしまうのですが、
項目1と項目6が「同じ項目のデータ一つ目、二つ目」という関係であれば、
foreach my $line(@lines){
my @colomns = split /\,/,$line;
}
これでカンマで区切られた各値が@Colmnsに格納されます。
$colomns[0]で項目1、$colomns[1]で項目2が取り出せます。
今回の場合の項目6は、一行目(項目1~5)の処理が終わった後に、繰り返し処理で$colomns[0]に上書されます。
上書される前にprintなどの望む出力を入れましょう。
お礼が遅くなり誠に申し訳ありませんでした。
先にお答え頂いた方の方法で問題なく表示できましたので、
まだお教え頂いた方法で試してはいないのですが、
こちらも今後の参考とさせて頂きます。
分かりやすいご説明をして頂き、ありがとうございました。
No.1
- 回答日時:
えー・・・っとよく分からないのですが、html上で改行入れるなら
print $hoge<br>;
でしょうか。読み込む部分も
my $io = IO::File->new('$LOG_FILE', 'r') or die $!;
my @lines = $io->getlines;
$io->close;
foreach my $line(@lines){
my @col = split /\,/,$line;
#以上でpushってしてる処理の部分おしまい。以下、ただの表示。
print "ids = $col[0]\n";
print "new_checks = $col[1]\n";
print "dates = $col[2]\n";
.........
}
のように思われます。
この回答への補足
早速ご回答頂きありがとうございます。
分かりづらい内容で申し訳ありません。
お伺いしたかったのはhtml上で改行をいれたいという内容ではなく、
CSVファイルの読み込みに関してなのです。
現在使用しているCGIは、CSVファイルの最後の項目の後にカンマがないと、
1行目と2行目の区別ができないようになっているのですが、
下記のBのように、それぞれの行の最後の項目にカンマがなくとも、
1行目と2行目を区別できるようにしたいと考えております。
CSVファイルの内容
--
A.※CGIで読み込みできる(項目6からは2行目と認識されます)
↓
項目1,項目2,項目3,項目4,項目5,
項目6,項目7,項目8,項目9,項目10,
B.※CGIで読み込みできない(項目5と6が同じ項目だとみなされる)
↓
項目1,項目2,項目3,項目4,項目5
項目6,項目7,項目8,項目9,項目10
もし実現出来る方法がありましたら、ご教授頂けると幸いです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- Ruby パイソンエラーについて 1 2022/12/24 14:07
- Visual Basic(VBA) 複数csvを横に追加していくマクロについて 2 2023/04/25 09:19
- Visual Basic(VBA) VBAで出力したCSVファイルの先頭にカンマを挿入したい 5 2022/10/14 12:20
- Ruby 教えてください 2 2023/01/04 17:50
- PHP 値の取り出し方について教えて下さい。 1 2023/03/31 13:30
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2023/05/23 16:28
- Excel(エクセル) エクセルのVBAについて とあるサイトのコードを参考に、CSVの文字化けを直すVBAを作成しているの 7 2022/11/04 14:15
- Visual Basic(VBA) フォルダの場所を可変にしたいです(マクロ) 4 2023/05/11 10:00
- Java javaのCSVデータ読込についてです 6 2022/07/02 10:58
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
MATLAB(マトラボ)とcsvファ...
-
ポインター引数の関数でコンパ...
-
htmlソース編集で、各タグを何...
-
UTF-8で5~6バイトになる文字コ...
-
stable diffusionのエラー
-
ビットスワップとバイトスワッ...
-
char str[256]の256の意味は?
-
10Mバイトて文字数に すると何...
-
Excel 1セル当りの文字数が2...
-
【Excel VBA】10進数を2進数に...
-
1KBが1024byteな理由
-
エクセルシート名の制限を変更...
-
Line Inputにて改行があっても...
-
異なるドメインのサイトでcooki...
-
全角半角を調べるライブラリ関...
-
CGIを勉強しています。¥n(改...
-
ピクセル,dpiから容量(バイト...
-
バイナリとBCDコード
-
VB6で漢字の1バイト目か2バイト...
-
PHPのCookieが有るか無いかで、...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
MATLAB(マトラボ)とcsvファ...
-
matlabで、平均値を求める方法...
-
VBScripの2次元動的配列
-
VBA エクセルで1列で表示したい。
-
いつどこゲームのようなテキス...
-
文字型変数を使って2進数表示す...
-
複数のCSVを一度にダウンロード
-
VB6.0でMSChartをタイマーを使...
-
ポインター引数の関数でコンパ...
-
10Mバイトて文字数に すると何...
-
UTF-8で5~6バイトになる文字コ...
-
Excel VBA メール作成について ...
-
char str[256]の256の意味は?
-
エクセルシート名の制限を変更...
-
stable diffusionのエラー
-
COBOLのCOMP形式について
-
Excel 1セル当りの文字数が2...
-
DataGridViewの特定列に入力さ...
-
バイナリとBCDコード
-
バイト列とバイナリ列の違いが...
おすすめ情報