Как рассчитать сумму значений строк для одного столбца таблицы, созданной с использованием TCPDF? - PullRequest
0 голосов
/ 14 февраля 2020

Не могли бы вы помочь мне вычислить и отобразить ЗНАЧЕНИЕ СУММЫ строк столбца с именем "prime" в моей таблице, созданной в отчете PDF с использованием TCPDF ( данные извлекаются из моей базы данных). Заранее спасибо. Я был бы очень признателен, если бы вы могли мне помочь. Лучшее описание моей таблицы результатов по этой ссылке Основная часть моего кода такая:

    <?php
set_time_limit(0);
tcpdf();


 // create new PDF document
$pdf = new TCPDF('L', PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8', false);

// remove default header/footer
$pdf->setPrintHeader(false);
$pdf->setPrintFooter(false);

// set default monospaced font
//$pdf->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED);

// set margins
//$pdf->SetMargins(PDF_MARGIN_LEFT, PDF_MARGIN_TOP, PDF_MARGIN_RIGHT);
$pdf->SetHeaderMargin(PDF_MARGIN_HEADER);
$pdf->SetFooterMargin(PDF_MARGIN_FOOTER);

// set auto page breaks
$pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_BOTTOM);

// set image scale factor
$pdf->setImageScale(PDF_IMAGE_SCALE_RATIO);

// set some language dependent data:
$lg = Array();
$lg['a_meta_charset'] = 'UTF-8';
$lg['a_meta_dir'] = 'rtl';
$lg['a_meta_language'] = 'fa';
$lg['w_page'] = 'page';

// set some language-dependent strings (optional)
$pdf->setLanguageArray($lg);

// ---------------------------------------------------------



// add a page
$pdf->AddPage();


$pdf->SetXY(16, 10);


// set document information
$pdf->SetCreator(PDF_CREATOR);
//$pdf->SetAuthor('Nicola Asuni');
//$pdf->SetSubject('TCPDF Tutorial');
//$pdf->SetKeywords('TCPDF, PDF, example, navettes, guide');
// set default header data
//$pdf->SetHeaderData(PDF_HEADER_LOGO, PDF_HEADER_LOGO_WIDTH, PDF_HEADER_TITLE.'', PDF_HEADER_STRING);
 $pdf->setPrintHeader(false);
// set header and footer fonts
$pdf->setHeaderFont(Array(PDF_FONT_NAME_MAIN, '', PDF_FONT_SIZE_MAIN));
$pdf->setFooterFont(Array(PDF_FONT_NAME_DATA, '', PDF_FONT_SIZE_DATA));



$pdf->setRTL(true);

$pdf->SetFont('xzar', '', 10);

    $sql= "SELECT * FROM nav_agent WHERE matricule='$mat'";  
    $query = $this->db->query($sql); 


$saut=0;
$tbl = '<table cellspacing="0" cellpadding="1" border="1">
   <thead>
        <tr>
            <th style="border: 1px double #000000; text-align:center;"  colspan="2">الإذن </th>
            <th style="border: 1px double #000000; text-align:center;"  colspan="2">التنقل</th>
            <th style="border: 1px double #000000; text-align:center;"  colspan="2">التوقيت</th>
            <th style="border: 1px double #000000; text-align:center;"  colspan="4"> </th>
       </tr>


<tr>
<td style="border: 1px double #000000; text-align:center;">العدد</td>  
<td style="border: 1px double #000000; text-align:center;">التاريخ</td>  
<td style="border: 1px double #000000; text-align:center;">من</td>  
<td style="border: 1px double #000000; text-align:center;">إلى</td>  
<td style="border: 1px double #000000; text-align:center;">الإنطلاق</td>  
<td style="border: 1px double #000000; text-align:center;">الرجوع</td>  
<td style="border: 1px double #000000; text-align:center;">المدة المقضاة (بالساعة)</td>  
<td style="border: 1px double #000000; text-align:center;"> مبلغ منحة التنقل </td> 
<td style="border: 1px double #000000; text-align:center;">رقم السيارة</td>
</tr>
';

$prime=0;
foreach ($query->result() as $row){

 $sql1 = "SELECT * FROM fiche_nav WHERE id_navette='$row->id_navette'";  


  $query1 = $this->db->query($sql1);    
foreach ($query1->result() as $row1){


$delai = strtotime($row1->heureret) - strtotime($row1->heuredep); 
$time_h = ($delai/60)/60; 


if ($val_grade == 'A1' or   $val_grade == 'A2')
    $montant1 = 15.000;
    else
        if ($val_grade == 'A3' or   $val_grade == 'B'  
         or     $val_grade =='ouv cat 8' or $val_grade =='ouv cat 9' or $val_grade =='ouv cat 10')  


    $montant1 = 9.000;
    else
        if ($val_grade == 'C' or    $val_grade == 'D'  
         or     $val_grade =='ouv cat 1' or $val_grade =='ouv cat 2' or $val_grade =='ouv cat 3'    
         or $val_grade =='ouv cat 4' or $val_grade =='ouv cat 5' or $val_grade =='ouv cat 6' or $val_grade =='ouv cat 7')

    $montant1 = 6.750;   


if ($val_grade == 'A1' or   $val_grade == 'A2')
    $montant2 = 35.000;
    else
        if ($val_grade == 'A3' or   $val_grade == 'B'  
         or     $val_grade =='ouv cat 8' or $val_grade =='ouv cat 9' or $val_grade =='ouv cat 10')  


    $montant2 = 25.000;
    else
        if ($val_grade == 'C' or    $val_grade == 'D'  
         or     $val_grade =='ouv cat 1' or $val_grade =='ouv cat 2' or $val_grade =='ouv cat 3'    
         or $val_grade =='ouv cat 4' or $val_grade =='ouv cat 5' or $val_grade =='ouv cat 6' or $val_grade =='ouv cat 7')

    $montant2 = 18.000;


if ( $time_h <= 7 )
$prime = 0;
else

    if ( $time_h >7 && $time_h <= 14 ) 
$prime = 0.5 * $montant1;

else


    if ( $time_h >14 && $time_h < 24 )
$prime = $montant1; 


else


    if ( $time_h >=24 ) 
$prime = $montant2;     

$tbl=$tbl. '<tr>
<td style="border: 0px solid #000000; text-align:center"></td>
<td style="border: 0px solid #000000; text-align:center">'. $row1->datedep .'</td>
<td style="border: 0px solid #000000; text-align:center">'. $row1->lieudep .'</td>
<td style="border: 0px solid #000000; text-align:center">'. $row1->destination .'</td>
<td style="border: 0px solid #000000; text-align:center">'. $row1->heuredep .'</td>
<td style="border: 0px solid #000000; text-align:center">'. $row1->heureret .'</td>
<td style="border: 0px solid #000000; text-align:center">'. $time_h .'</td>
<td style="border: 0px solid #000000; text-align:center">'. $prime .'</td>
<td style="border: 0px solid #000000; text-align:center;"> '.$row1->matriculevoiture .' </td>

<td style="border: 0px solid #000000; text-align:center"></td>
<td style="border: 0px solid #000000; text-align:center"></td>
<td style="border: 0px solid #000000; text-align:center"></td>
<td style="border: 0px solid #000000; text-align:center"></td>
<td style="border: 0px solid #000000; text-align:center"></td>
</tr>
' ;

}


}

$tbl=$tbl.' </thead></table> ';


$pdf->writeHTML($tbl, true, false, false, false, '');


  // WHAT SHALL I ADD HERE TO CALCULATE the TOTAL VALUE i.e SUM OF "$PRIME" ROWS?

// close and output PDF document
 $date_auj=date('dmY',NOW());
    $strr = "Rapport-".$date_auj.".pdf";
$pdf->Output($strr, 'I');
//ob_end_clean(); 
//$pdf->Output($strr, 'I');

//============================================================+
// END OF FILE
//============================================================+
?>

Ответы [ 3 ]

0 голосов
/ 14 февраля 2020

После строки

$prime=0;

Добавьте еще одну переменную, назовите ее $sumPrimes

$sumPrimes =0;

И после последней, когда вы назначите $prime:

else
    if ( $time_h >=24 ) 
$prime = $montant2;

Вы можете рассчитать сумму следующим образом:

$sumPrimes += $prime;

После каждого foreach и до закрытия таблицы:

$tbl=$tbl.' </thead></table> ';

Вы можете напечатать $sumPrimes.

0 голосов
/ 17 февраля 2020

Спасибо вам, дорогие участники, за вашу драгоценную помощь! Действительно, другая переменная суммы отсутствовала. Я решил проблему, добавив ее, как показано ниже:

$grandPrime=0; $prime=0; 

foreach ($query->result() as $row)

{ // МОИ ЕСЛИ УСЛОВИЯ ДЛЯ РАСЧЕТА СТОИМОСТИ ПРАВА et c ..

$grandPrime+=$prime; 

$tbl=$tbl. '<tr> 

/ / MY TABLE CONTENT..et c.

</tr> ' ; } 
$pdf->writeHTML($tbl, true, false, false, false, ''); 

// Затем я добавил A для L OOP, чтобы отобразить grandPRIME VALUE, где $ num_prime - это просто число простых строк

$num_prime = count($prime);
 for($i = 0; $i < $num_prime; ++$i) 
{ $pdf->SetFont('xzar', 'B', 11);
 $pdf->Cell(277,5, " المبلغ الجملي $grandPrime ",1,0,'C'); 
} 

Это правильный результат, который я наконец-то получил: Пожалуйста, кликните c ссылку, чтобы увидеть картинку

СПАСИБО СНОВА :)) ВЫ ДЕЙСТВИТЕЛЬНО ПОМОГИЛИ МНЕ!

0 голосов
/ 14 февраля 2020

вы можете объявить переменную до $prime variable

$grandPrime=0;
$prime=0;
foreach ($query->result() as $row){

, инициализировать ее здесь

$grandPrime+=$prime;
$tbl=$tbl. '<tr>
<td style="border: 0px solid #000000; text-align:center"></td>
<td style="border: 0px solid #000000; text-align:center">'. $row1->datedep .'</td>

и использовать ее после конца l oop.

...