1

テンプレートの発注書を設定するためにphpexcelを使用しようとしています。25~43列目は購入商品の詳細を設定しております。これは、データベースからデータを取得し、列 25 のすべての値を 43 に設定することを意味します。さらに、これらの列は 6 項目にのみ適合します。購入アイテムが多すぎて、設定した列に収まらないという問題に直面しています。私のコードは機能していますが、長すぎます。誰もがより良い解決策を持っていますか? 両方のシートを作成した後、両方のシートで他のセル値を1つずつ設定する必要があります。コードが非常に長くなります。誰が助けてくれるか感謝します。

   $objPHPExcel->setActiveSheetIndex(0);

  $result = mysql_query("SELECT purchasematerial.PONum,purchasematerial.QuoNum,purchasematerial.date,           material.product,purchasematerial.description,purchasematerial.unit_price,purchasematerial.UOM,purchasematerial.qua        ntity ,purchasematerial.amount FROM purchasematerial INNER JOIN material ON        purchasematerial.product=material.id where PONum='$PONum'");
   $col=25;
  $num=1;
  while($row = mysql_fetch_array($result)){

 if($col<43){
 $objPHPExcel->getActiveSheet()->setCellValue('AA11', $row['PONum']);
 $date = new DateTime($row['date']);
 $objPHPExcel->getActiveSheet()->setCellValue('AA12', $date->format('d-M-y'));
 $objPHPExcel->getActiveSheet()->setCellValue('I45', '=AA12+7');
 $QuoNum=$row['QuoNum'];
 if ($QuoNum=='' || $QuoNum== null)
 $objPHPExcel->getActiveSheet()->setCellValue('I47', "N/A");
else
$objPHPExcel->getActiveSheet()->setCellValue('I47', $row['QuoNum']);
$objPHPExcel->getActiveSheet()->setCellValue('A'.$col, $num);
$objPHPExcel->getActiveSheet()->setCellValue('B'.$col, $row['product']);
$objPHPExcel->getActiveSheet()->SetCellValue('J'.$col, $row['description']);
$objPHPExcel->getActiveSheet()->SetCellValue('S'.$col, $row['unit_price']);
$objPHPExcel->getActiveSheet()->setCellValue('V'.$col, $row['UOM']);
$objPHPExcel->getActiveSheet()->SetCellValue('Y'.$col, $row['quantity']);
$objPHPExcel->getActiveSheet()->SetCellValue('AB'.$col, $row['amount']);
$col=$col+3;  
$num++;
}

else{

$objPHPExcel->createSheet();
$objPHPExcel->setActiveSheetIndex(1);
$col=25;
$objPHPExcel->getActiveSheet()->setCellValue('AA11', $row['PONum']);
$date = new DateTime($row['date']);
$objPHPExcel->getActiveSheet()->setCellValue('AA12', $date->format('d-M-y'));
$objPHPExcel->getActiveSheet()->setCellValue('I45', '=AA12+7');
$QuoNum=$row['QuoNum'];
if ($QuoNum=='' || $QuoNum== null)
$objPHPExcel->getActiveSheet()->setCellValue('I47', "N/A");
else
$objPHPExcel->getActiveSheet()->setCellValue('I47', $row['QuoNum']);
$objPHPExcel->getActiveSheet()->setCellValue('A'.$col, $num);
$objPHPExcel->getActiveSheet()->setCellValue('B'.$col, $row['product']);
$objPHPExcel->getActiveSheet()->SetCellValue('J'.$col, $row['description']);
$objPHPExcel->getActiveSheet()->SetCellValue('S'.$col, $row['unit_price']);
$objPHPExcel->getActiveSheet()->setCellValue('V'.$col, $row['UOM']);
$objPHPExcel->getActiveSheet()->SetCellValue('Y'.$col, $row['quantity']);
$objPHPExcel->getActiveSheet()->SetCellValue('AB'.$col, $row['amount']);
$col=$col+3;  
$num++;
}
}

$objPHPExcel->setActiveSheetIndex(0);
$objPHPExcel->getActiveSheet()->getStyle('I45')->getNumberFormat()-    >setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_DATE_XLSX15);
$objPHPExcel->getActiveSheet()->setCellValue('AC1', 'WEEKNUM(I45)');
$objPHPExcel->getActiveSheet()->setCellValue('Q44', 'TOTAL');
$objPHPExcel->getActiveSheet()->SetCellValue('Y44','RM');
$objPHPExcel->getActiveSheet()->SetCellValue('AB44', '=SUM(AB25:AB43)');
$objPHPExcel->getActiveSheet()->getStyle('Q44')->getFont()->setBold(true);
$objPHPExcel->getActiveSheet()->getStyle('Y44')->getFont()->setBold(true);
$objPHPExcel->getActiveSheet()->getStyle('AA44')->getFont()->setBold(true);

 $objPHPExcel->setActiveSheetIndex(1);
 $objPHPExcel->getActiveSheet()->getStyle('I45')->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_DATE_XLSX15);
$objPHPExcel->getActiveSheet()->setCellValue('AC1', 'WEEKNUM(I45)');
 $objPHPExcel->getActiveSheet()->setCellValue('Q44', 'TOTAL');
 $objPHPExcel->getActiveSheet()->SetCellValue('Y44','RM');
$objPHPExcel->getActiveSheet()->SetCellValue('AB44', '=SUM(AB25:AB43)');
$objPHPExcel->getActiveSheet()->getStyle('Q44')->getFont()->setBold(true);
$objPHPExcel->getActiveSheet()->getStyle('Y44')->getFont()->setBold(true);
$objPHPExcel->getActiveSheet()->getStyle('AA44')->getFont()->setBold(true);
4

1 に答える 1

0

流暢なインターフェイスを使用するのも 1 つの方法かもしれません。

それ以外の

$objPHPExcel->getActiveSheet()->setCellValue('I47', $row['QuoNum']);
$objPHPExcel->getActiveSheet()->setCellValue('A'.$col, $num);
$objPHPExcel->getActiveSheet()->setCellValue('B'.$col, $row['product']);
$objPHPExcel->getActiveSheet()->SetCellValue('J'.$col, $row['description']);
$objPHPExcel->getActiveSheet()->SetCellValue('S'.$col, $row['unit_price']);
$objPHPExcel->getActiveSheet()->setCellValue('V'.$col, $row['UOM']);
$objPHPExcel->getActiveSheet()->SetCellValue('Y'.$col, $row['quantity']);
$objPHPExcel->getActiveSheet()->SetCellValue('AB'.$col, $row['amount']);

行う

$objPHPExcel->getActiveSheet()->setCellValue('I47', $row['QuoNum'])
    ->setCellValue('A'.$col, $num)
    ->setCellValue('B'.$col, $row['product'])
    ->SetCellValue('J'.$col, $row['description'])
    ->SetCellValue('S'.$col, $row['unit_price'])
    ->setCellValue('V'.$col, $row['UOM'])
    ->SetCellValue('Y'.$col, $row['quantity'])
    ->SetCellValue('AB'.$col, $row['amount']);

あなたが絶えず電話をかけないように$objPHPExcel->getActiveSheet()

セルは最初のシートと同じであるため、2 番目のシートを設定します。セルの値を設定する関数を作成し、その関数を 2 回呼び出すだけです (基本的な PHP 101)。または、最初のシートのセルを設定してから、そのシートを複製し、その複製を 2 番目のシートとして設定することもできます。

于 2013-10-09T08:04:08.710 に答える