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

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

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

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

PHP

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

Q&A

解決済

1回答

563閲覧

PHP CSVファイルから読み込み表示

hello_mate

総合スコア21

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

PHP

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

0グッド

0クリップ

投稿2019/08/24 12:22

csvファイルを読み込み、1行づつカンマ区切りの値を各場所
<input type="" value="<?= print ---- ?>">
この部分のところに表示したいと思っているのですが

PHPでファイルの中身を取り、foreachで取った値をvar_dump確認すると
array(4){[0]=>string(1)"1"[1]=>string(4)"Mike"[2]=>string(14) "Mike@gmail.com"[3]=>string(5)"hello"}
array(4){[0]=>string(1)"2"[1]=>string(4)"Tom"[2]=>string(14) "Tom@gmail.com"[3]=>string(5)"hello"}
array(4){[0]=>string(1)"3" [1]=>string(4)"Brian"[2]=>string(14)"Brian@gmail.com"[3]=> string(5)"hello"}
と、取得できたいるのですが

HTML部分で表示するときに
文字コードをまだ変換していないので文字化けしてしまったり
<br /><b>Notice</b>: Uninitialized string offset: 1 in <b>
とエラーが出てきてしまったり。という状況になってしまいます。

php

1<?php 2 $fp = fopen("account.csv", "r"); 3 while($data = fgetcsv($fp, 10000)){ 4 foreach($data as $row){ 5 $result = explode(',', $row); 6 var_dump($result); 7 } 8 } 9 10?> 11<!DOCTYPE html> 12<html lang="ja" dir="ltr"> 13 <head> 14 <meta http-equiv="Content-Type" content="text/html; charset=Shift_JIS"> 15 <title></title> 16 </head> 17 <body> 18 <h1>アカウント</h1> 19 <?php foreach($result as $row){ ?> 20 <input type="text" name="id" value="<?= print $row[0] ?>"> 21 <input type="text" name="name" value="<?= print $row[1]?>"> 22 <input type="text" name="email" value="<?= print $row[2]?>"> 23 <input type="textarea" name="contents" value="<?= print $row[3]?>"><br> 24 <?php } ?> 25 </body> 26</html>

csv

11,Mike,Mike@gmail.com,hello 22,Tom,Tom@gmail.com,hello 33,Brian,Brian@gmail.com,hello

お手数ですが、エラーが起こっている部分などの改善策を教えていただけると幸いです。
よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

PHP

1var_dump($result);

は$resultを使用する直前で行わないと意味が無いです。

修正箇所としては

PHP

1$result = explode(',', $row);

PHP

1$result[] = explode(',', $row);

で多分動くと思います。

var_dump($result);をいろいろな場所に仕掛けて、変数の状態遷移を確認してみると理由がわかると思います。

投稿2019/08/24 16:09

tanat

総合スコア18713

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

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

hello_mate

2019/08/25 16:21

ご回答ありがとうございます。 おっしゃっていただいた通り、var_dump($result)の位置がwhile分の中で行なっていたのを、while終了後に書き込んで確認してみたところ、綺麗に配列が取れていることを確認できました。 array(3) { [0]=> array(4) { [0]=> string(1) "1" [1]=> string(4) "aaaa" [2]=> string(14) "aaaa@gmail.com" [3]=> string(7) "hello " } [1]=> array(4) { [0]=> string(1) "2" [1]=> string(4) "bbbb" [2]=> string(14) "bbbb@gmail.com" [3]=> string(7) "hello " } [2]=> array(4) { [0]=> string(1) "3" [1]=> string(4) "cccc" [2]=> string(14) "cccc@gmail.com" [3]=> string(5) "hello" } } ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問