代码的第一部分工作正常,但是第二部分(显示结果)工作错误。如果我要插入$slugs = explode(',', $slugs)
里面foreach ($pma...)
,它会给我explode() expects parameter 2 to be string, array given
错误。如果我现在保留它,它可以工作,但是结果以“马赛克,散乱”模式给出,具有多个相同的结果。甚至print_r()
每行显示800个结果(这是胡说八道)。
如何解决这个问题?
$data = fopen('php://output', 'w');
$fields = rtrim($_GET['fieldnames'], ",");
$slugs = rtrim($_GET['slugs'], ",");
$fieldnames = array();
$fieldslugs = array();
$pma = DB::table... // long query
$fields = explode(',', $fields);
foreach ($fields as $field) {
$fieldnames[] = $field;
}
fputcsv($data, $fieldnames);
$slugs = explode(',', $slugs);
foreach ($pma as $p) {
foreach ($slugs as $slug) {
$fieldslugs[] = $p->$slug;
}
fputcsv($data, $fieldslugs);
}
对不起,英语不好,坦克也没答案!
试试这个:
foreach ($pma as $p) {
$fieldslugs = [];
foreach ($slugs as $slug) {
$fieldslugs[] = $p->$slug;
}
fputcsv($data, $fieldslugs);
}
您需要为每次迭代重置数组,否则它将继续填充相同的数组,从而将新的行结果附加到每个csv行。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句