php распечатать массив в строку
Конвертировать массив в строку при помощи PHP
Если вам потребовалось преобразовать массив php в строку, то для этого есть несколько инструментов. Применение того или иного инструмента зависит от ваших целей.
Теперь поговорим о конвертации массива в строку:
1. Функция implode()
С ее помощью можно «склеить» элементы массива в строку, через любой разделитель. Подробнее: implode
Пример:
Подобным образом мы можем преобразовать только одномерные массивы и у нас пропадут ключи.
2. Функция join()
Работает точно так же как и implode(), поскольку это просто псевдоним, выбирайте название, которое больше нравится.
Пример у нас будет идентичный:
3. Функция serialize()
Затем из этой строки, можно снова получить массив:
4. Функция json_encode()
Возвращает JSON представление данных. В нашем случае, данная функция, напоминает сериализацию, но JSON в основном используется для передачи данных. Вам придется использовать этот формат для обмена данными с javascript, на фронтенде. Подробнее: json_encode
Обратная функция json_decode() вернет объект с типом stdClass, если вторым параметром функции будет false. Либо вернет ассоциативный массив, если передать true вторым параметром
5. Функция print_r
Она подходит для отладки вашего кода. Например вам нужно вывести массив на экран, чтобы понять, какие элементы он содержит.
6. Функция var_dump
Функция var_dump также пригодится для отладки. Она может работать не только с массивами, но и с любыми другими переменными, содержимое которых вы хотите проверить.
7. Функция var_export
var_dump не возвращает значение, но при желании это конечно можно сделать через буферизацию.
array_to_string
Как таковой функции array_to_string в php нет, но есть описанные выше инструменты, которых более чем достаточно для выполнения задачи. Я просто хотел напомнить, что вы никогда не ограничены этими инструментами, и можете написать то, что подходит именно под вашу задачу.
Как сделать работу с массивами еще проще?
Если вы используете библиотеку для работы с коллекциями, то ваш код для преобразования массива в строку может выглядеть куда более изящно:
Также рекомендую обратить внимание на полезную библиотеку для работы со строками. С ее помощью вы можете выполнять операции со строками более удобно и с меньшим количеством кода.
На этом все. Обязательно прочитайте справку по данным функциям и пишите если у вас остались вопросы.
PHP: конвертирование массива в строку
В этой статье разберем как преобразовывать массив в строку и обратно.
Есть два способа преобразовать массив в строку в PHP.
Использование функции implode()
Используя функцию implode(), мы можем преобразовать все элементы массива в строку. Параметр разделителя в функции implode() является необязательным. Но хорошей практикой будет использовать оба аргумента.
В приведенном выше примере в первой строке объявлена переменная массива и ей присвоены некоторые значения.
Вы также можете преобразовать полученную строку если требуется обратно в массив. Для этого мы можем использовать функцию PHP explode().
Функция explode()
Используя функцию explode(), мы можем преобразовать строку в элементы массива. Мы можем передать три аргумента. Первый разделитель, второй массив и последний лимит (ограничение длинны).
В приведенном выше примере строковой переменной присваивается некоторое значение. Затем функция explode() разбивает эту строку на массив. После этого мы использовали функцию print_r(), которая печатает все элементы массива и его индексы.
Использование функции json()
В PHP объекты могут быть преобразованы в строку JSON с помощью функции json_encode().
В приведенном выше примере мы присвоили значение переменной объекта, а затем в json_encode() преобразовали значение в переменную массива и создали ассоциативный массив.
implode
(PHP 4, PHP 5, PHP 7, PHP 8)
implode — Объединяет элементы массива в строку
Описание
Альтернативная сигнатура (не поддерживается с именованными аргументами):
Устаревшая сигнатура (устарела с PHP 7.4.0, удалена в PHP 8.0.0):
Список параметров
По умолчанию равен пустой строке.
Массив объединяемых строк.
Возвращаемые значения
Возвращает строку, содержащую строковое представление всех элементов массива в указанном порядке, с разделителем между каждым элементом.
Список изменений
Версия | Описание |
---|---|
8.0.0 | Передача separator после array больше не поддерживается. |
7.4.0 | Передача separator после array (т.е. использование недокументированного порядка параметров) устарела. |
Примеры
Пример #1 Пример использования implode()
Примечания
Замечание: Эта функция безопасна для обработки данных в двоичной форме.
Смотрите также
User Contributed Notes 14 notes
it should be noted that an array with one or no elements works fine. for example:
It’s not obvious from the samples, if/how associative arrays are handled. The «implode» function acts on the array «values», disregarding any keys:
declare( strict_types = 1 );
Can also be used for building tags or complex lists, like the following:
?>
This is just an example, you can create a lot more just finding the right glue! 😉
It might be worthwhile noting that the array supplied to implode() can contain objects, provided the objects implement the __toString() method.
$array = [
new Foo ( ‘foo’ ),
new Foo ( ‘bar’ ),
new Foo ( ‘qux’ )
];
TRUE became «1», FALSE became nothing.
Also quite handy in INSERT statements:
// build query.
$sql = «INSERT INTO table» ;
Even handier if you use the following:
This threw me for a little while.
If you want to implode an array as key-value pairs, this method comes in handy.
The third parameter is the symbol to be used between key and value.
// output: x is 5, y is 7, z is 99, hello is World, 7 is Foo
null values are imploded too. You can use array_filter() to sort out null values.
Sometimes it’s necessary to add a string not just between the items, but before or after too, and proper handling of zero items is also needed.
In this case, simply prepending/appending the separator next to implode() is not enough, so I made this little helper function.
If you want to use a key inside array:
Example:
$arr=array(
array(«id» => 1,»name» => «Test1»),
array(«id» => 2,»name» => «Test2»),
);
echo implode_key(«,»,$arr, «name»);
OUTPUT: Test1, Test2
It is possible for an array to have numeric values, as well as string values. Implode will convert all numeric array elements to strings.
print_r
(PHP 4, PHP 5, PHP 7, PHP 8)
print_r — Выводит удобочитаемую информацию о переменной
Описание
print_r() выводит информацию о переменной в удобочитаемом виде.
Список параметров
Выражение для вывода на экран.
Возвращаемые значения
Примеры
Пример #1 Пример использования print_r()
Результат выполнения данного примера:
Пример #2 Пример использования параметра return
Примечания
Смотрите также
User Contributed Notes 36 notes
I add this function to the global scope on just about every project I do, it makes reading the output of print_r() in a browser infinitely easier.
Here is another version that parses the print_r() output. I tried the one posted, but I had difficulties with it. I believe it has a problem with nested arrays. This handles nested arrays without issue as far as I can tell.
I always use this function in my code, because most of my functions return an Array or Boolean :
?>
( print_r gives no output on FALSE and that can be annoying! )
This works around the hacky nature of print_r in return mode (using output buffering for the return mode to work is hacky. ):
The following will output an array in a PHP parsable format:
Here is a print_r that produces xml:
(now you can expand/collapse the nodes in your browser)
// replace ‘)’ on its own on a new line (surrounded by whitespace is ok) with ‘
A simple function to send the output of print_r to firebug.
The script creates a dummy console object with a log method for when firebug is disabled/not available.
This is an alternative for printing arrays. It bolds array values.
I was having problems using print_r because I didn’t like the fact that if tags where included in the array it would still be parsed by the browsers.
Heres a simple fix for anyone who is having the same problem as I did. This will output your text properly for viewing through the browser instead of the browser’s «view source» or CLI.
A slight modification to the previous post to allow for arrays containing mutli line strings. haven’t fully tested it with everything, but seems to work great for the stuff i’ve done so far.
$output = ‘
Array
(
[a] => apple
[b] => banana
[c] => Array
(
[0] => x
[1] => y
[2] => z
[3] => Array
(
[nest] => yes
[nest2] => Array
(
[nest] => some more
asffjaskkd
)
[nest3] => o rly?
)
)
)
?>
This should output
print_r is used for debug purposes. Yet I had some classes where I just wanted the values coming out of the database, not all the other crap. thus i wrote the following function. If your class has an toArray function, that one will be called otherwise it will return the object as is. print_neat_classes_r is the function that should be called!
Here is a print_r() clone but support max level limit.
When we want to print a big object, this will help us get a clean dumping data.
$test = new testClass ;
testClass Object
(
[a:protected] => aaa
[b:testClass:private] => bbb
[c] => Array
(
[0] => 1
[1] => 2
[2] => Array
*MAX LEVEL*
[d:static] => ddd
[e:protected:static] => eee
[testClass] =>
*RECURSION*
You cannot use print_r(), var_dump() nor var_export() to get static member variables of a class. However, in PHP5 you can use Reflection classes for this:
I use this all the time when debugging objects, but when you have a very large object with big arrays of sub-objects, it’s easy to get overwhelmed with the large amount of output. sometimes you don’t want to see absolutely every sub-object.
I made this function to debug objects while «hiding» sub-objects of certain types. This also color codes the output for a more readable printout.
If you have to catch the output without showing it at all at first (for example, if you want to append the print_r output to a file), you can do this:
Another slight modification to the previous post to allow for empty array elements
my take on the highlighted markupped debug function:
/**
* print_array()
* Does a var_export of the array and returns it between » );
>
?>
For those of you needing to print an array within a buffer callback function, I’ve created this quick function. It simply returns the array as a readable string rather than printing it. You can even choose whether to return it in normal text-mode or HTML. It’s recursive, so multi-dimensial arrays are supported. I hope someone finds this useful!
Here’s a PHP version of print_r which can be tailored to your needs. Shows protected and private properties of objects and detects recursion (for objects only!). Usage:
test Object (
[var1] => a
[var2:protected] => b
[var3:private] => c
[array:protected] => Array (
[0] => x
[1] => y
[2] => z
)
[recursiveRef] => *RECURSION*
[anotherRecursiveRef] => stdClass Object (
[recursiveRef] => *RECURSION*
)
)
Another attempt that tries to overcome the memory blowout when the passed in data has mutual recursion.
I include the entire function below for completeness, but all credit to Matt, the original author, Thank You.
We had an interesting problem dumping an object that
contained embedded HTML. The application makes use
of buffer manipulation functions, so print_r’s 2nd argument
wasn’t helpful. Here is how we solved the problem:
Массив в строку в PHP?
Я хочу сохранить его как одну строку в моей базе данных с каждой записью, разделенных | :
11 ответов
потом просто использовать json_decode () для декодирования строки из вашей БД. все остальное бесполезно, JSON сохраняет отношение массива нетронутым для последующего использования!
нет, вы не хотите хранить его как одну строку в своей базе данных.
можно использовать serialize() но это сделает ваши данные труднее искать, труднее работать с ними и тратить пространство.
вы также можете сделать другую кодировку, но она обычно склонна к той же проблеме.
вся причина, по которой у вас есть DB, заключается в том, что вы можете выполнять такую работу тривиально. Вам не нужна таблица для хранения массивов, вам нужна таблица, которую вы можете представлять в виде массива.
вы просто выберите данные из таблицы с SQL, а не иметь таблицу, которая выглядит как:
это не то, как кто-то разрабатывает схему в реляционной базе данных, это полностью разрушает ее цель.
один из лучших способов:
почему JSON: вы можете использовать его с большинством языков программирования, строка, созданная функцией serialize () php, читается только в PHP, и вам не понравится хранить такие вещи в своих базах данных, особенно если база данных разделяется между приложениями, написанными на разных языках программирования
однако, инкогнито прав, вы, вероятно, не хотите хранить его таким образом-это полная трата реляционной мощности вашей базы данных.
Если вы не настроены на сериализацию, вы также можете использовать json_encode ()