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

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

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

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

PHP

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

Q&A

解決済

2回答

1576閲覧

fputcsvのファイル出力について

panjaA

総合スコア67

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

PHP

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

0グッド

1クリップ

投稿2017/08/23 01:30

posgresql9.5のtimestamp型に入っている
"2017-08-22 07:09:55"のデータを取得し
fputcsv($file,$data);(php5.3)
でファイルへ出力する際、"2017-08-22 07:09:55"で出力されます。

出力時に""ダブルクオーテーションなしで出力したいです。
2017-08-22 07:09:55

よろしくお願いします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

文字列であるため何かで括られる必要があります。

引数で括る文字は指定できますが初期値があるように必須の項目であり、
例えば''のように空文字は指定できません。
PHPマニュアル:fputcsv

例えば、strtotime()等で変換してしまえば数値扱いとなりダブルクォーテーションはつきませんが・・。

ダブルクォーテーションで括られたくない理由(要は用途)は何でしょうか?

投稿2017/08/23 01:51

m.ts10806

総合スコア80850

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

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

panjaA

2017/08/23 01:59

ありがとうございます。 dbのカラムがtimestampとidがあり、 fputcsv()で出力した時、 ファイルの中身が "2017-08-22 07:09:55",12のようになるため ダブルクオーテーションなしで統一したいと思いました。
m.ts10806

2017/08/23 02:09 編集

idは見た目数字のみなので付きませんね。 timestamp型は「-」「:」のような記号や半角スペースも含むため「文字列」としてPHPは扱います。 なぜかというと文字列なのでクォーテーションやセルの区切りである「,」等も入る可能性があるからです。 例えば 「2017-08-22 07:"09:55」のように途中に"が入っているようなケースはエスケープする必要があるため""とエスケープ用にダブルクォーテーションが追加されます。 DBから取得してきた文字列を直接利用しているとしてもPHP側にとっては単なる文字列に過ぎないため、 文字列解釈される場合は必ず何かで囲われる仕様になっているようです。 csvを利用するケースといえばExcelでの加工がよくあり、 クォーテーションであればExcelで開いたときに見えるわけではないので(セルの区切りとして解釈される)大丈夫だろうとは思っていたのですが、用途によりつけられないケースもあるのではと確認がてら、質問させていただきました。
panjaA

2017/08/23 04:36

ありがとうございます。 String型のカラムのデータはfputcsv()出力した際、""はつかないのですが timestamp型のカラムのデータはfputcsv()出力した際、""で囲まれます。 CSV出力ではなくTSV出力を行いたいとき、""なしに統一したいのですが、 何か方法ありますでしょうか?
m.ts10806

2017/08/23 04:59

色々試してみました。 スペースを含んでいることが囲みの対象となっているように思います。 timestamp型には日付と時間の間に半角スペースがありますので、 半角スペースを別の記号などに置き換えてはいかがでしょうか? 全てのパターン網羅するほどの検証はできていませんが、 半角スペースを別の記号に置き換えた場合は囲われずに出力できています。 ※timestamp型としての効力は失うので扱う際には要注意です ただ、囲われている状態が基本正しい状態であり、データの形式として不正なわけでもないので、 あまり統一することにこだわらない方がいいとも思います。 (それも要件次第ですね)
panjaA

2017/08/23 05:02

回答ありがとうございます。半角スペースを何かに置き換えて出力したいと思います!
m.ts10806

2017/08/23 05:08

完全に動作保証できたわけではありませんので、実際のデータと運用からしっかりと検証してから導入してください。
guest

0

既にBest Answerついているのですが、代替案として下記はいかがでしょうか?

PHP

1//これはダブルクォーテーションで囲われない 2//field 1 field 2 field3hasNoSpaces 2017-08-22 07:09:55 3$outputFile = fopen('./data/test.csv', "w"); 4$res = ["field 1","field 2","field3hasNoSpaces","2017-08-22 07:09:55"]; 5fputs($outputFile, implode($res, "\t")."\n");

投稿2018/04/03 02:55

motuo

総合スコア3027

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問