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

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

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

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

Q&A

解決済

2回答

433閲覧

PHP:JSON_ENCODEで得られるデータが、キーと値双方が「"」くくられてしまっている。文字列のみを「”」でくくるようにしたい。

saya24

総合スコア247

PHP

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

0グッド

0クリップ

投稿2020/06/29 07:29

編集2020/06/29 07:44

標題のとおり、明らかに数値項目である 金額・単価までも 「"」でくくられていて困っています。
こちらのページに json_encodeで 指定可能なオプションが定義されていますが

JSON_NUMERIC_CHECKを指定すると、数値項目から「"」が除去されるのですが、前「0」が付いているテーブルのKeyになっているような文字列までも、数値項目と判断され、ZEROサプレスされかつ「"」が除去されてしまう事態を招いています。

かたやJSON_BIGINT_AS_STRINGを指定すると、先に言及の前「0」が付いている項目が文字列と認識されるも
金額・単価といった明らかな数値項目までも 「"」でくくられてしまいます。

前「0」の項目は文字列の項目と判断した上、数値のみの項目は 数値項目と判断するような 指定はできないでしょうか?

16:40追記

JSON

1[ 2 { 3 "受注NO": "0001791904", 4 "エントリNO": "0001610538", 5 "運賃": "0", 6 "税抜合計金額": "0" 7 }, 8 { 9 "受注NO": "0001791916", 10 "エントリNO": "0001610550", 11 "運賃": "0", 12 "税抜合計金額": "0" 13 } 14]

PHP

1header('Content-Type: application/json; charset=UTF-8'); 2header("X-Content-Type-Options: nosniff"); 3echo json_encode($json, JSON_UNESCAPED_UNICODE | JSON_PRETTY_PRINT | JSON_BIGINT_AS_STRING); 4exit();

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

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

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

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

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

maisumakun

2020/06/29 07:32

PHPでどのような形の連想配列を、どのような形のJSONにしたいのでしょうか。具体的にコードで示していただければと思います。
maisumakun

2020/06/29 07:34

JSON_BIGINT_AS_STRINGとありますが、JavaScriptでそのまま扱いづらい、53ビットを超える整数を扱う状況なのでしょうか?
退会済みユーザー

退会済みユーザー

2020/06/29 07:50

人間が視認して数値だと認知するものでも、データ処理上の書き方で文字列として扱っているなら、文字列として出力するだけのことのような。
guest

回答2

0

ベストアンサー

金額・単価といった明らかな数値項目までも 「"」でくくられてしまいます。

PHPにとっては、全く明らかではありません。json_encodeする前に、これらの値を数値に変換しておきましょう。

投稿2020/06/29 07:45

maisumakun

総合スコア146018

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

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

maisumakun

2020/06/29 07:47

正しく整数と文字列の型で値を入れておけば、json_encodeする際に特殊な引数は不要です。
saya24

2020/06/29 07:54

$i = oci_fetch_all($stmt, $results, null, null, OCI_FETCHSTATEMENT_BY_ROW); で、OracleデータベースからSELECT文の結果を 変数 $results に得ていますが これを $json に格納した上で json_encodeに利用しました。 データベースから出力した項目は データベース側の属性を引きついで現れる認識だったのですが、そんな簡単にはいかないでしょうか? それとも、PHP.iniに 当該プロバイダに関わる 何か設定がなされている、ということでしょうか??
maisumakun

2020/06/29 07:55

> データベースから出力した項目は データベース側の属性を引きついで現れる認識だったのですが、そんな簡単にはいかないでしょうか? そうですね、PHPでデータベースにアクセスすると、数値も文字列として取れる場面がちょくちょくあります。
saya24

2020/06/29 07:56

そっかぁそっかぁ やはりうまくいかないものですねぇ
guest

0

普通にやれば数値にはクォーテーションはつきません

PHP

1$a=[1,2,"x",4]; 2print json_encode($a);

投稿2020/06/29 07:31

編集2020/06/29 07:32
yambejp

総合スコア116724

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

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

yambejp

2020/06/29 07:33

想定通りにならない具体的なデータを提示して質問ください
yambejp

2020/06/29 08:07 編集

追記のJSONデータをみても、受注NOやエントリNOが文字列で 運賃や税抜合計金額が数値であると判断できる情報がなにもありません。 ・わたすデータをきちんと最初から整備するか ・なんらかのジャッジをする基準をきめるか
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問