【发布时间】:2018-11-13 13:10:55
【问题描述】:
我有一个名为:$messages 的数组,其中包含此数据。 (动态生成)。
如何为每个 txt_id 创建一个包含 3 列(txt、时间和名称)的 CSV 文件?
array(3) {
[0]=>
array(5) {
["txt"]=>
string(3) "Hey"
["txt_id"]=>
string(1) "5"
["name"]=>
string(8) "John Doe"
["id_user"]=>
string(1) "5"
["time"]=>
string(19) "2017-12-15 08:28:47"
}
[1]=>
array(5) {
["txt"]=>
string(8) "Hey John"
["txt_id"]=>
string(1) "5"
["name"]=>
string(13) "Gilles Ragout"
["id_user"]=>
string(1) "58"
["time"]=>
string(19) "2017-12-15 08:37:21"
}
[2]=>
array(5) {
["txt"]=>
string(6) "What ?"
["txt_id"]=>
string(2) "12"
["name"]=>
string(11) "Noémie Nail"
["id_user"]=>
string(1) "56"
["time"]=>
string(19) "2017-05-10 05:12:36"
}
所以结果应该是 Messages1.csv 和 Messages2.csv 因为我们有 2 个不同的 txt_id。
并且 csv 文件的输出应该是 Messages1.csv :
txt | time | name
Hey 2017-12-15 08:28:47 John Doe
Hey John 2017-12-15 08:37:21 Gilles Ragout
对于 Messages2.csv :
txt | time | name
What ? 2017-05-10 05:12:36 Noemie Nail
我尝试使用此代码。
$file = fopen('php://temp', 'w');
if (false === $file) {
die('Failed to create temporary file');
}
foreach ($getUserConv as $conv) {
fputcsv($file, array_keys($conv));
fputcsv($file, $conv);
}
rewind($file);
$zip->addFromString(__('Conversations').'.csv', stream_get_contents($file));
fclose($file);
这段代码的结果是一个大的 csv 文件,其中包含所有对话,但缺少列名,并且标题重复。
例如,我生成了对话,输出为:
txt | time
Hi 2017-12-18 01:01:10
txt | time
Yo 2017-12-18 02:10:08
【问题讨论】:
-
到目前为止你尝试了什么?
-
对不起,我更新了我的帖子。
标签: php arrays csv merge fputcsv