yaml_parse
(PECL yaml >= 0.4.0)
yaml_parse — Разбирает поток YAML
Описание
Конвертирует весь поток YAML или его часть и записывает в переменную.
Список параметров
-
input -
Строка для парсинга как поток YAML.
-
pos -
Документ для разбора (
-1для всех документов,0для первого документа, ...). -
ndocs -
Если
ndocsнайден, тогда он будет заменен на количество документов в потоке YAML. -
callbacks -
Обработчики содержимого для узлов YAML. Ассоциативный массив (array), ключи которого являются тегами YAML, а значения callback-функциями (callable), которые будут их обрабатывать. Более подробно этот механизм описан в разделе callback-функции разбора.
Возвращаемые значения
Возвращает значение, закодированое в input, в соответствующем
типе PHP или false в случае возникновения ошибки. Если параметр pos равен
-1, будет возвращен массив, содержащий по одной записи для каждого
документа, найденого в потоке.
Примеры
Пример #1 Пример использования yaml_parse()
<?php
$yaml = <<<EOD
---
invoice: 34843
date: "2001-01-23"
bill-to: &id001
given: Chris
family: Dumars
address:
lines: |-
458 Walkman Dr.
Suite #292
city: Royal Oak
state: MI
postal: 48046
site: zxibit.esy.es
ship-to: *id001
product:
- sku: BL394D
quantity: 4
description: Basketball
price: 450
- sku: BL4438H
quantity: 1
description: Super Hoop
price: 2392
tax: 251.420000
total: 4443.520000
comments: Late afternoon is best. Backup contact is Nancy Billsmer @ 338-4338.
...
EOD;
$parsed = yaml_parse($yaml);
var_dump($parsed);
?>
Результатом выполнения данного примера будет что-то подобное:
array(8) {
["invoice"]=>
int(34843)
["date"]=>
string(10) "2001-01-23"
["bill-to"]=>
&array(3) {
["given"]=>
string(5) "Chris"
["family"]=>
string(6) "Dumars"
["address"]=>
array(4) {
["lines"]=>
string(34) "458 Walkman Dr.
Suite #292"
["city"]=>
string(9) "Royal Oak"
["state"]=>
string(2) "MI"
["postal"]=>
int(48046)
}
}
["ship-to"]=>
&array(3) {
["given"]=>
string(5) "Chris"
["family"]=>
string(6) "Dumars"
["address"]=>
array(4) {
["lines"]=>
string(34) "458 Walkman Dr.
Suite #292"
["city"]=>
string(9) "Royal Oak"
["state"]=>
string(2) "MI"
["postal"]=>
int(48046)
}
}
["product"]=>
array(2) {
[0]=>
array(4) {
["sku"]=>
string(6) "BL394D"
["quantity"]=>
int(4)
["description"]=>
string(10) "Basketball"
["price"]=>
int(450)
}
[1]=>
array(4) {
["sku"]=>
string(7) "BL4438H"
["quantity"]=>
int(1)
["description"]=>
string(10) "Super Hoop"
["price"]=>
int(2392)
}
}
["tax"]=>
float(251.42)
["total"]=>
float(4443.52)
["comments"]=>
string(68) "Late afternoon is best. Backup contact is Nancy Billsmer @ 338-4338."
}
Примечания
Обрабатывать непроверенный пользовательский ввод, в случае когда для узлов YAML,
использующих тег !php/object, разрешено использование функции unserialize(), крайне опасно. Это поведение можно отключить с помощью
ini-настройки yaml.decode_php.
Смотрите также
- yaml_parse_file() - Разбирает YAML-поток из файла
- yaml_parse_url() - Разбирает YAML-поток из URL
- yaml_emit() - Возвращает YAML-представление значения