Ответ 1
Нет, так, как ты это делаешь, все в порядке. implode()
принимает только 1-2 параметра (если вы просто поставляете массив, он соединяет куски с пустой строкой).
Импробирование простого массива
будет выглядеть следующим образом:
$array = array('lastname', 'email', 'phone');
$comma_separated = implode(",", $array);
и это вернет этот
lastname,email,phone
отлично, поэтому я могу сделать это вместо
$array = array('lastname', 'email', 'phone');
$comma_separated = implode("','", $array);
$comma_separated = "'".$comma_separated."'";
и теперь у меня есть то, что я хочу красивую симпатичную строку csv
'lastname','email','phone'
Есть ли лучший способ сделать это, мне кажется, что должен быть необязательный параметр для implode, я что-то пропустил?
Нет, так, как ты это делаешь, все в порядке. implode()
принимает только 1-2 параметра (если вы просто поставляете массив, он соединяет куски с пустой строкой).
$array = array('lastname', 'email', 'phone');
echo "'" . implode("','", $array) . "'";
Вы можете использовать array_map()
:
function add_quotes($str) {
return sprintf("'%s'", $str);
}
$csv = implode(',', array_map('add_quotes', $array));
Также обратите внимание, что есть fputcsv
, если вы хотите записать в файл.
Не знаю, быстрее ли это, но вы можете сохранить строку кода с помощью своего метода:
С
$array = array('lastname', 'email', 'phone');
$comma_separated = implode("','", $array);
$comma_separated = "'".$comma_separated."'";
To:
$array = array('lastname', 'email', 'phone');
$comma_separated = "'".implode("','", $array)."'";
$ids = sprintf("'%s'", implode("','", $ids ) );
Если вы хотите использовать циклы, вы также можете:
$array = array('lastname', 'email', 'phone');
foreach($array as &$value){
$value = "'$value'";
}
$comma_separated = implode(",", $array);
В качестве альтернативы вы можете создать такую функцию:
function implode_with_quotes(array $data)
{
return sprintf("'%s'", implode("', '", $data));
}
вы можете сделать это так же и
<?php
$csv= '\'' . join(array('lastname', 'email', 'phone'),'\',').'\'';
echo $csv;
?>
Я думаю, что это то, что вы пытаетесь сделать
$array = array('lastname', 'email', 'phone');
echo "'" . implode("','", explode(',', $array)) . "'";
Если вы хотите избежать подсистемы fopen/fputcsv здесь, фрагмент, который строит экранированную строку CSV из ассоциативного массива....
$output = '';
foreach ($list as $row) {
$output .= '"' . implode('", "', array_values($row)) . '"' . "\r\n";
}
Или из списка объектов...
foreach ($list as $obj) {
$output .= '"' . implode('", "', array_values((array) $obj)) . '"' . "\r\n";
}
Затем вы можете вывести строку по желанию.