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

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

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

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

3回答

10473閲覧

csvのダブルクオーテーションを外したい

coinbura

総合スコア106

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2018/04/03 02:31

PHPで以下のようなコードを組み、タブ区切りのcsvを作成したのですが、日付がダブルクオーテーションで囲まれてしまい、既存システムで読み込んだ時にエラーが出てしまいます。
どうにかダブルクオーテーションを消す事はできないものでしょうか?

$fp = fopen($outputFile, 'w'); while($res = $stmt->fetch(PDO::FETCH_ASSOC)){ fputcsv($fp, $res,"\t"); } fclose($fp);

ちなみに、fcloseの前で
$fp = trim($fp,'"');
としてみたのですが、だめでした。

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

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

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

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

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

guest

回答3

0

php fputcsv enclosure empty でぐぐりました。

このStackOverflow の議論がまんま今回のご質問にあてはまると思いますが、

fputcsvを使う限り、なんかしらの文字(デフォルトではダブルクォート)で囲われてしまうのはどうしようもなさそうです。
自前でfputsしろ、と上記でも言っています。

投稿2018/04/03 02:45

kazto

総合スコア7196

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

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

coinbura

2018/04/03 02:55

なるほど、fputcsvでは不可能なんですね(^^A 勉強になりました。
guest

0

ベストアンサー

fputcsvではmts10806さんの回答にあるとおり、囲み文字を無くす設定まではできません。
自前でcsv文字列(この場合タブ区切りなのでtsvですが)を生成してファイルに書き込みましょう。
こんな感じでどうでしょうか。

PHP

1fputs($fp, implode("\t", $res) . "\n");

投稿2018/04/03 02:48

ttyp03

総合スコア16996

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

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

coinbura

2018/04/03 02:55

できました!! この2日間、悩みに悩んだ難問が一瞬で!!! ほんとに感謝感謝です!!!
guest

0

第4引数で任意の囲み文字が指定できますが、囲み文字を外すなど省略はできません。
PHPマニュアル:fputcsv

私が過去に似たような質問に回答していました。

参考にしてください。

どちらかというと既存システムで「エラーが出るように組まれている」ことが問題に思います。
csvから情報を取得する際にきちんと組めばダブルクォーテーションではエラーとならないはずです。

投稿2018/04/03 02:35

編集2018/04/03 02:41
m.ts10806

総合スコア80765

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

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

coinbura

2018/04/03 02:45

ご回答ありがとうございます。 timestampの形を変更する形は既存システムが受け入れてくれないので、ちょっと厳しいです(^^A もちろん既存システムがおかしいのは重々承知しているのですが、そのシステムに対して何も変更を加える事ができない状況ですので、なかなか厳しい状況なのです(TT)
m.ts10806

2018/04/03 02:47

fputcsvを使う以上は何かしら囲み文字がある状態なので、 file_put_contents()なりなんなりで自身でcsvを作られてはいかがでしょうか。
m.ts10806

2018/04/03 02:48

と書いていたら別の回答にその旨がありますね。
coinbura

2018/04/03 02:55

勉強になりました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問