Php implode (101) с кавычками

Импробирование простого массива

будет выглядеть следующим образом:

$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, я что-то пропустил?

Ответ 1

Нет, так, как ты это делаешь, все в порядке. implode() принимает только 1-2 параметра (если вы просто поставляете массив, он соединяет куски с пустой строкой).

Ответ 2

$array = array('lastname', 'email', 'phone');


echo "'" . implode("','", $array) . "'";

Ответ 3

Вы можете использовать array_map():

function add_quotes($str) {
    return sprintf("'%s'", $str);
}

$csv =  implode(',', array_map('add_quotes', $array));

DEMO

Также обратите внимание, что есть fputcsv, если вы хотите записать в файл.

Ответ 4

Не знаю, быстрее ли это, но вы можете сохранить строку кода с помощью своего метода:

С

$array = array('lastname', 'email', 'phone');
$comma_separated = implode("','", $array);
$comma_separated = "'".$comma_separated."'";

To:

$array = array('lastname', 'email', 'phone');
$comma_separated = "'".implode("','", $array)."'";

Ответ 5

$ids = sprintf("'%s'", implode("','", $ids ) );

Ответ 6

Если вы хотите использовать циклы, вы также можете:

$array = array('lastname', 'email', 'phone');
foreach($array as &$value){
   $value = "'$value'";
}
$comma_separated = implode(",", $array);

Демо: http://codepad.org/O2kB4fRo

Ответ 7

В качестве альтернативы вы можете создать такую ​​функцию:

function implode_with_quotes(array $data)
{
    return sprintf("'%s'", implode("', '", $data));
}

Ответ 8

вы можете сделать это так же и

<?php
$csv= '\'' . join(array('lastname', 'email', 'phone'),'\',').'\'';
echo $csv;
?>

Ответ 9

Я думаю, что это то, что вы пытаетесь сделать

$array = array('lastname', 'email', 'phone');
echo "'" . implode("','", explode(',', $array)) . "'";

Ответ 10

Если вы хотите избежать подсистемы 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";
}

Затем вы можете вывести строку по желанию.