如何使用dompdf一键打印500多个pdf,而每个pdf可以有n页



我有100多个项目,项目有不同的数据。我想一键打印n个pdf,每个pdf可以有n个页面。我使用foreach并获取结果,但当项目有2000+行(1页有25行(时,它的获取超时。这是我的代码:

$finalItems = array('1,2,3,4',5,6,..............);
foreach($finalItems as $item){
$i++;

$getGrp =  DB::table('item_master')->select('group')->where('item_name', $item)->get();
$rs = json_decode(json_encode($getGrp), true);
$getGP = call_user_func_array('array_merge', $rs);
$saleData =  DB::table('sale_data')->where('item_name', $item)->where('site_id', $site_id)->whereBetween('bill_date',[$_POST['fromDate'],$_POST['toDate']])->get();
$purchaseData=  DB::table('purchase_data')->where('item_name', $item)->where('site_id', $site_id)->whereBetween('bill_date',[$_POST['fromDate'],$_POST['toDate']])->get(); 
$stock_trf =  DB::table('stock_transfer')->where('item_name',$item)->where('site_id', $site_id)->whereBetween('bill_date',[$_POST['fromDate'],$_POST['toDate']])->get();   

$sales = json_decode(json_encode($saleData), true);
$purchase = json_decode(json_encode($purchaseData), true);
$stock = json_decode(json_encode($stock_trf), true);
$res = array_merge($sales, $purchase, $stock);

$groupName = $getGP['group']; 
$pdf = PDF::loadView('myPDF', compact('res'));
$pdf->setPaper('a3', 'landscape');
$pdf->save(public_path().'/pdf/item_'.$item.'.pdf')>stream('item_'.$item.'.pdf');
$pdf_name[] = 'item_'.$item.'.pdf';
}

/******************HTML视图文件*******************************/

@$dlr = array_chunk($res, 100);
$loopCount = count($dlr);
@for($i=0; $i<$loopCount; $i++)
@foreach ($dlr[$i] as $sldata[$i])
<tr >
<td style="width:2%"></td>
<td style="width:5.10%"></td>
<td style="width:9.10%"></td>
<td style="width:7.10%"></td>
<td style="width:5.10%">{{ $sldata[$i]['batch_no'] }}</td>
<td style="width:5.10%">{{ $sldata[$i]['mfg_date'] }}</td>
<td style="width:5.10%">{{ $sldata[$i]['exp_date'] }}</td>
<td style="width:5.10%"></td>
<td style="width:5.10%"></td>
<td style="width:5.10%"></td>
<td style="width:3.10%">{{ $last_balance }}</td>
<td style="width:5.10%"></td>
<td style="width:3.10%">{{ $sldata[$i]['quantity_in_kgltr'] }}</td>
<td style="width:4.10%"></td>
<td style="width:4.10%"></td>
<td style="width:5.10%">
<?php 
$tocl = (int)$sldata[$i]['quantity_in_kgltr'];
echo @$last_balance -= $tocl; ?>
</td>
<td style="width:5.10%">{{ $sldata[$i]['bill_no'] }}</td>
<td style="width:5.10%">{{  date('d-m-Y', strtotime($sldata[$i]['bill_date'])) }}</td>
<td style="width:8.10%">{{ $sldata[$i]['sales_to_customer_name'] }}</td>
<td style="width:3.10%"></td>
</tr>
@endforeach
@endfor

所以你确实得到了一个超时?

对于一份长期工作来说,这是意料之中的事。简单的解决方法是增加超时:设置时间限制

但是,如果仍然需要很长时间,您可能会遇到其他超时(尤其是Web服务器:Apache或IIS或其他(

打印这么多PDF文档并不完全是Web服务器的工作。

我建议您考虑一种解决方案,即在没有Web服务器的情况下使用PHP,也就是命令行。

请确保将set_time_limit设置为0(意味着它不会终止(。

你发布的脚本片段清楚地表明你正在制作一个网页。如果您需要从网页中进行选择,请找到一种方法将选择转移到将运行命令行的脚本中。(例如,将PDF文件名写入文件。然后从PDF打印脚本中读取该文件(

使用array_cchunk((实现的任务:

$flag = 0;
$chunks = array_chunk($res, 100);
foreach($chunks as $listitems){
$flag++;  
$groupName = @$getGP['group'];
view()->share('group',$groupName);
view()->share('fromdt',$fromDate); 
view()->share('siteid',$site_id);
view()->share('inm',$inm); 
$pdf = PDF::loadView('myPDF', compact('listitems'));
$pdf->setPaper('a3', 'landscape');
$pdf->save(public_path().'/pdf/item_'.$item.''.$flag.'.pdf')->stream('item_'.$item.''.$flag.'.pdf');
$pdf_name[] = 'item_'.$item.''.$flag.'.pdf';
} 

相关内容

  • 没有找到相关文章

最新更新