MySql からデータを取得して、Excel でレポートを作成しようとしています。データベースから件名の見出しを取得し、それらを列として Excel シートに出力する必要があります (例: セル: D5、E5、F5 ... M5 など)。
これまでのところ、私はそうすることができたので、セルの下の表示には次のような見出しが表示されます。
D5:数学、E5:英語、F5:物理など
| A | B | C | D | E | F | G | H |
--------------------------------------------------------------
1 | | | | | | | | |
...
5 | | | | Mathematics | English | Physics | ... | ... |
これは問題ありません。課題は、各s の間に次のようなGRADE
見出しを挿入する必要があることです。Subject
| A | B | C | D | E | F | G | H | I | J | K |
--------------------------------------------------------------------------------------
1 | | | | | | | | | | | |
...
5 | | | | Mathematics | GRADE | English | GRADE | Physics | GRADE | ... | ... |
ここに私がこれまでに持っているものがあります:
$stringindex = "DEFGHIJKLMNOPQRSTUVWXYZ"; // For the excel column cells
$arr_index = str_split($stringindex); // create array elements
$arr_val2 = array(); // create array
$subject = array();
$subname2 = array();
while($sub_row = mysqli_fetch_array($resub, MYSQLI_ASSOC)) {
$subject[] = $sub_row['name']; // Get the subjects from the database and put them in an array
}
foreach($subject as $sub => $subname) {
$subkey[] = $sub; // array of subject keys e.g 0|1|2|3
$subname2[] = $subname; // array of subjects
}
foreach($arr_index as $arr => $arr_val) {
$arr_val2[] = $arr_val; // array of letters e.g D|E|F|G
}
$acount = count($subname2);
$bcount = count($arr_val2);
$size = ($acount > $bcount) ? $bcount : $acount;
$a = array_slice($subname2, 0, $size);
$b = array_slice($arr_val2, 0, $size);
$combine = array_combine($a, $b);
$sheet = $objPHPExcel->setActiveSheetIndex(0); // PHPExcel functions
foreach($combine as $key => $val) { // GET SUBJECTS
$objPHPExcel->getActiveSheet()->getColumnDimension($val)->setAutoSize(true); // Sets Column Width
$sheet
->setCellValue($val.'5', $key); // Lists Subjects as columns
} // END of FOREACH LOOP
上記のコードは、件名を Excel の列見出しとして表示できます。
質問: 各件名の見出しの後に GRADE 列を追加するコードを追加するにはどうすればよいですか?
私はあなたが私を正しい方向に向けてくれることを願っています.coz '私は今立ち往生しています.
前もって感謝します。