ポンクソフト

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

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

お名前:


カルティエ ソリテール
ブランドコピーブランドN級品専門店
史上最も激安ブランドブランドコピー-即日 配送可,100%入荷。
当店は正規品と同等品質は品質3年保証でご注文から5 日でお届け致します。
レディースとメンズ激安通販専門店!品質と本物は同様です。
全て新品、高い品質、激安 、送料は無料です( 日本全国)すべての商品は品質2年無料保証です。
ブランドコピー時計:
2017/03/24 14:04

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


ああああ
2017/03/23 00:54

オメガ ボーイズ
★2017最高等級新しい商品大量入荷!
■在庫情報随時更新!(*^-^*)
■信用第一、良い品質、低価格は。
★歓迎光臨★送料無料(日本全国)
ご注文を待ちしております
よろしくお願いいたします_(._.)_
2017/03/22 09:09


テスト
2017/03/21 14:02

ゆうた
かりんがすき
2017/03/17 14:36

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

残りを読む »