ポンクソフト

CSVファイルの読み込み - PHPでファイルの読み書き・掲示板

前ページ PHPでファイルの読み書き・掲示板 TOP 次ページ

目次

  1. PHPでファイルの読み書き・掲示板
  2. ファイルの読み込み
  3. ファイルの書き込み
  4. ファイルの読み書き(ゲストブック)
  5. 設定ファイルの読み書き
  6. CSVファイルの読み込み
  7. テキストエディタの作成
  8. アンケートシステムの作成
  9. 掲示板1(シンプル)

CSVファイルの読み込み1

ExcelやAccessといったアプリケーションからデータを読み込んで表示する場合、CSVファイルを使うと簡単に実現することができます。
CSVファイルとは、各項目のデータをカンマで区切ったテキストファイルのことです。

CSVファイルの作成

Excelがある場合はそれを立ち上げ、以下のようにデータを入力してください。
エクセル画面
入力を終えたら、メニューの「ファイル」→「名前を付けて保存」のダイアログボックスから、ファイルの形式を「CSV(カンマ区切り)」、ファイル名に「donut.csv」と付けて保存してください。途中でいくつか注意が出るかも知れませんが、すべて「はい」でOKです。

Excelがない場合は、テキストエディタで直接以下のように入力して、ファイル名「donut.csv」で保存してください。画面端で折り返されている行は、実際に入力するときに改行を入れてはいけません。
オールドファッション,ミルクをたっぷり使ったクッキータイプの定番ドーナツ。
ダブルチョコレート,ココアを配合したケーキタイプの生地にチョコレートをコーティング。
フレンチクルーラー,グレーズがたっぷりかかった風味豊かなドーナツ。
エンゼルフレンチ,ホイップクリームをサンドしてチョコレートでコーティングしたスウィートなドーナツ。
カスタードクリーム,口どけのよいイースト生地にカスタードクリームがたっぷり。
ポン・デ・リング,ハチミツの香り豊かなグレーズをたっぷりコーティング。もちもちとした食感。

プログラムの作成

次にCSVファイルを読み込んで画面に表示するプログラムを作成します。以下のソースを入力してください。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html lang="ja">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=Shift_JIS">
<title>CSVファイルを読み込む1</title>
</head>
<body>
<?php
$fp = fopen("donut.csv", "r");
while ($data = fgetcsv($fp, 10000)) {
  foreach ($data as $d) {
    print $d . "<br>\n";
  }
}
?>
</body>
</html>
入力が終わったら「csvread1.php」というファイル名で保存し、サーバに「csvread1.php」「donut.csv」の両方をアップし、実行してみてください。

ソースの解説

while ($data = fgetcsv($fp, 10000)) {
fgetcsv関数は、CSVファイルから一行を読み出し、各項目を配列として返す関数です。
1つ目の引数は読み込むファイルのファイルポインタです。2つ目の引数は読み込む行の最大長です。十分な長さを指定しておけば良いでしょう。
戻り値は、例えば一行目を読み込んだとき、$data[0] に「オールドファッション」、$data[1] に「ミルクをたっぷり使ったクッキータイプの定番ドーナツ。」という値が入ります。

CSVファイルの読み込み2

CSVデータをテーブルを使って整形して出力してみます。

プログラムの作成

以下のソースを入力してください。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html lang="ja">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=Shift_JIS">
<title>CSVファイルを読み込む2</title>
</head>
<body>
<table border="1">
<?php
$fp = fopen("donut.csv", "r");
while ($data = fgetcsv($fp, 10000)) {
  print "<tr>";
  foreach ($data as $d) {
    print "<td>$d</td>";
  }
  print "</tr>\n";
}
?>
</table>
</body>
</html>
入力が終わったら「csvread2.php」というファイル名で保存し、サーバにアップし、実行してみてください。
前ページ PHPでファイルの読み書き・掲示板 TOP 次ページ
このエントリーをはてなブックマークに追加 そっか0

このページに関するコメントをどうぞ

お名前:


toyokazumori
とても参考になりました。
とにかくわかりやすく、自分のつくりたいものに応用することが簡単にできました。
ありがとうございます。
2017/04/25 17:06

R
親切丁寧な解説ありがとうございます
最後までがんばりたいと思います
2017/04/25 16:55


すごく参考になりました!
ありがとうございます。
2017/03/30 09:47

カリマー
解りやすくて、とてもいいサイトですね!
phpは初心者ですが、最後まで到達できるよう頑張ります!
2017/03/23 04:03

saraebo
別windowsとして実装することなく、actionのphpで、コマンドとするデータベース等の更新で、その結果をクライアントに返さない(homeページの元画面は変わらない。)とする事はできるのでしょうか?
2017/03/17 12:09

ミーコ
テスト
2017/03/16 17:27

NsArk(プログラミング初心者)
非常に細かく書いていただき、大変参考になります!
ただ一点。
自身に理解力が本当に残念です・・・。
orz
2017/03/14 18:41

参考になりました
シンプルで分かりやすく、とても参考になりました。
色々なPHPシンプル掲示板のサイトを見ましたが、
ここが一番です。
ありがとうございました。
2017/03/12 20:15


hp初心者ですがコピペさせて下さい。出来たら報告しますね^v^
2017/03/03 11:38

yyyy
初心者です。MySQLのパスワード設定について教えてください。
下の文でDBを開くコマンド入力した際、外部からパスワードが見える
ことは無いのでしょうか?
$pdo = new PDO("mysql:dbname=bennkyou;charset=utf8", "root","123");
*上の文の 123 がパスワードとしたとき。
どうぞ宜しくお願い致します。
2017/01/16 23:04

残りを読む »