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

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

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

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

2回答

8287閲覧

tableの表示の仕方

jal0994

総合スコア20

PHP

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2016/04/03 15:27

編集2016/04/03 15:56

Array
(
[0] => Array
(
[date] => 0301
[新規] => 23
[退会] => 4
)

[1] => Array ( [date] => 0302 [新規] => 5 [退会] => 3 ) [2] => Array ( [date] => 0303 [新規] => 9 [退会] => 3 )

上記のような配列データ を、foreachで下記のようなtableで表示させたいのですが、可能でしょうか?
イメージ説明
HTMLで書くと下記のようになるのですが、上記の配列のデーターの持ち方でforeachを使って上手く表示させる方法が思いつきません。ご教示いただければと思います。

<table border="1"> <tr> <td colspan="2">空白</td> <td>0301</td> <td>0302</td> <td>0303</td> <tr> <td rowspan="2">グループA</td> <td>新規</td> <td>23</td> <td>5</td> <td>9</td> </tr> <tr> <td>退会</td> <td>4</td> <td>3</td> <td>7</td> </tr> </table>

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

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

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

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

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

kei344

2016/04/03 15:32

試しにコードを書いてみてください。
jal0994

2016/04/03 15:50

HTMLで書くと下記のような書き方になるのですが、質問の記載している配列のデータの持ち方だと上手く表示させる方法が思いつかないです。 <table border="1"> <tr> <td colspan="2">空白</td> <td>0301</td> <td>0302</td> <td>0303</td> <tr> <td rowspan="2">グループA</td> <td>新規</td> <td>23</td> <td>5</td> <td>9</td> </tr> <tr> <td>退会</td> <td>4</td> <td>3</td> <td>7</td> </tr> </table>
guest

回答2

0

php

1<?php 2 3$entries = [ 4 ['date' => '0301', '新規' => 23, '退会' => 4], 5 ['date' => '0302', '新規' => 5, '退会' => 3], 6 ['date' => '0303', '新規' => 9, '退会' => 3], 7]; 8 9// $entriesが以下の条件を満たしている前提のコード 10// ・ $entriesは空にならない 11// ・ $entriesの各要素が必ず「date」「新規」「退会」の順番でキーを持つ 12$columns = array_combine(array_keys(current($entries)), array_map(null, ...$entries)); 13 14function h($str) { 15 return htmlspecialchars($str, ENT_QUOTES, 'UTF-8'); 16} 17 18header('Content-Type: text/html; charset=UTF-8'); 19 20?> 21<!DOCTYPE html> 22<title>Example</title> 23<table border="1"> 24 <tr> 25 <td colspan="2">空白</td> 26<?php foreach ($columns['date'] as $date): ?> 27 <td><?=h($date)?></td> 28<?php endforeach; ?> 29 </tr> 30 <tr> 31 <td rowspan="2">グループA</td> 32 <td>新規</td> 33<?php foreach ($columns['新規'] as $count): ?> 34 <td><?=h($count)?></td> 35<?php endforeach; ?> 36 </tr> 37 <tr> 38 <td>退会</td> 39<?php foreach ($columns['退会'] as $count): ?> 40 <td><?=h($count)?></td> 41<?php endforeach; ?> 42 </tr> 43</table>

もしPHP5.6より古い場合

php

1$columns = array_combine(array_keys(current($entries)), array_map(null, ...$entries));

ここの...がエラーになると思うので

php

1$columns = array_combine( 2 array_keys(current($entries)), 3 call_user_func_array('array_map', array_merge([null], $entries)) 4);

でどうぞ.

【補足】
一応以下に手続き型で分かりやすく書いたバージョンも示しておきます.foreachでベターっと書くのが嫌いじゃなければこっちでもいいです.動作速度はこっちのほうが速いです.

php

1$columns = []; 2foreach ($entries as $i => $entry) { 3 foreach ($entry as $key => $value) { 4 $columns[$key][$i] = $value; 5 } 6}

投稿2016/04/03 16:17

編集2016/04/03 17:43
mpyw

総合スコア5223

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

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

jal0994

2016/04/03 23:54

参考にさせていただきます! ご丁寧な回答本当にありがとうございました!
mpyw

2016/04/04 13:42

複数グループあると思いますが,どのグループも0301〜0331のエントリをこの順番で持つようになっていますよね?(一応確認
jal0994

2016/04/04 23:12

そうですね。 他の方達の回答を参考にして、解決できそうです! 気にかけていただきありがとうございます!
guest

0

ベストアンサー

回答が閉じていなかったので、別の方法を回答します。
もし解決されているようであれば、「解決済」にされてはいかがでしょうか。

PHP

1<?php 2// 複数グループがある前提で。 3$groups = array( 4 'グループA' => array( 5 array( 'date' => '0301', '新規' => 23, '退会' => 4 ) 6 , array( 'date' => '0302', '新規' => 5, '退会' => 3 ) 7 , array( 'date' => '0303', '新規' => 9, '退会' => 3 ) 8 ) 9 , 'グループB' => array( 10 array( 'date' => '0301', '新規' => 23, '退会' => 4 ) 11 , array( 'date' => '0302', '新規' => 5, '退会' => 3 ) 12 , array( 'date' => '0303', '新規' => 9, '退会' => 3 ) 13 ) 14// , 'グループC' => array( 15// array( 'date' => '0304', '新規' => 23, '退会' => 4 ) 16// , array( 'date' => '0305', '新規' => 5, '退会' => 3 ) 17// , array( 'date' => '0306', '新規' => 9, '退会' => 3 ) 18// ) // グループごとにdateがそろわない例 19); 20$res = ''; 21foreach ( $groups as $name => $entries ) { 22 $keys = array_keys( current( current( $groups ) ) ); 23 $cnt = count( $keys ); 24 for ( $i = 0; $i < $cnt; $i++ ) { 25 if ( $i === 0 && $res !== '' ) { continue; }; // グループごとにdateがそろわない場合はこの行をコメントアウト 26 $tr = ''; 27 $key = $keys[ $i ]; 28 $tag = ( $i === 0 ) ? 'th' : 'td'; 29 30 if ( $i === 0 ) { 31 $tr .= _s( '', 'th',' colspan="2"', 2 ); 32 } else { 33 if ( $i === 1 ) { 34 $tr .= _s( _h( $name ), 'th',' rowspan="'.( $cnt - 1 ).'"', 2 ); 35 }; 36 $tr .= _s( _h( $key ), 'th', '', 2 ); 37 }; 38 foreach ( $entries as $ii => $entry ) { 39 $tr .= _s( _h( $entry[ $key ] ), $tag, '', 2 ); 40 } 41 $res .= _s( $tr, 'tr', '', 1 ); 42 } 43} 44// 出力する 45echo _s( $res, 'table', '', 0 ); 46 47// エスケープ 48function _h( $str ) { 49 $str = (string) $str; 50 return ( 0 === strlen( $str ) ) ? '' : htmlspecialchars( $str, ENT_QUOTES, 'UTF-8' ); 51} 52// 描画補助 53function _s( $html, $tag, $attr, $depth = 0 ) { 54 return sprintf( '%5$s%4$s<%2$s%3$s>%1$s%5$s%4$s</%2$s>' 55 , /* %1$s */ $html 56 , /* %2$s */ $tag 57 , /* %3$s */ ( strlen( $attr ) > 0 ) ? ' '.$attr : '' 58 , /* %4$s */ ( $depth > 0 ) ? str_repeat( "\t", $depth ) : '' 59 , /* %5$s */ "\n" 60 ); 61} 62// 63 ?> 64

投稿2016/04/04 12:08

kei344

総合スコア69407

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

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

jal0994

2016/04/04 23:10

解決済みに関して、ご指摘いただきありがとうございます。 このようなやり方があるんですね。参考にさせていただき、何とか解決できそうです! お時間を割き、このような丁寧な回答をしていただき、本当にありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問