данные из xml в mysql, помогите
Страницы: 1
данные из xml в mysql, помогите
Вообще суть такая, что нужно сделать экспорт данных из xml файла в бд.
сам файл https://drive.google.com/open?id=0B4kSeitV2ouoQjdEQTF4cHI0OVlBaGIxSHhEUDhMREJUT0ZJ .
Получаю из этого файла объект
$file = $_SERVER['DOCUMENT_ROOT'].'/web/xml/import.xml';
$xml = simplexml_load_file($file);

Как я понял, там категории товар, подкатегории и сами товары.
Думал разделить и сделать отдельные запросы для отдельных категорий.
Как получить всё по отдельности?
Пытаюсь взять допустим все ид категорий
foreach ($xml AS $rez) {
    echo $rez -> Группы->Группа->Ид;
}
Вывод только самый первый ид и останавливается.
Помогите плз или дайте ссылку где можно разобраться. Сам гуглил уже, никак не смог разобраться.

Прогон по твиттеру, постинг в 1500 аккунтов
Постинг в твиттер аккаунты, для ускорения индексации ваших сайтов, сателлитов, дорвеев.

Не знаю ваш уровень.

Посмотрите для начала, что в переменной $xml получилось. Будет удобно обращаться и от туда брать.

Посмотреть можно так:
Код
<?php
echo '<pre>';
print_r ($xml);
echo '</pre>';

Копируете это в notepade++ и смотрите по скобкам, что к чему относится



Код для вашего примера:
Код
<?php
$file = $_SERVER['DOCUMENT_ROOT'].'/web/xml/import.xml';
$xml= simplexml_load_file($file);

$groups = $xml->Классификатор->Группы->Группа;
foreach ($groups as $group) {
   echo $group->Ид.' ';
   echo $group->Наименование.'<br>';
} 
 
Возможно, проблемы с кириллицей. Если заменить на латинские буквы (код снизу), то таких  проблем не возникает, но появляется другая. В Группах вложенные Группа, в них есть свои Группы, поэтому так, по-простому, выдрать все ид не получится.

foreach ($xml->Classif->Groups->Group as $group) {
   echo $group->Id . ' '; echo $group->Name .'<br>';

}
Изменено: oleg zarubin - 22 Августа 2018 10:04
Цитата
Андрей Кривушонок пишет:
Вообще суть такая, что нужно сделать экспорт данных из xml файла в бд.
сам файл https://drive.google.com/open?id=0B4kSeitV2ouoQjdEQTF4cHI0OVlBaGIxSHhEUDhMREJUT0ZJ .
Получаю из этого файла объект
$file = $_SERVER['DOCUMENT_ROOT'].'/web/xml/import.xml';
$xml = simplexml_load_file($file);

Как я понял, там категории товар, подкатегории и сами товары.
Думал разделить и сделать отдельные запросы для отдельных категорий.
Как получить всё по отдельности?
Пытаюсь взять допустим все ид категорий
foreach ($xml AS $rez) {
echo $rez -> Группы->Группа->Ид;
}
Вывод только самый первый ид и останавливается.
Помогите плз или дайте ссылку где можно разобраться. Сам гуглил уже, никак не смог разобраться
Данным циклом не обойти дерево данного xml.
Примерно так можно спарсить группы:



Код
<?php
$file = $_SERVER['DOCUMENT_ROOT'].'/import.xml';
$xml = simplexml_load_file($file); 

$json = json_encode($xml);
$array = json_decode($json,TRUE);

$group = [];
function get_group($data, &$group, $parent = ''){
    foreach($data as $key=>$value){
        if(isset($data['Ид'])){
                $group[$data['Ид']] = [
                    'id' => $data['Ид'],
                    'parent_id' =>  $parent,
                    'name' => $data['Наименование']
                ];

            if($key == 'Группы' && isset($data[$key]['Группа'])){
                get_group($data[$key]['Группа'], $group, $data['Ид']);
            }
        }else{
            if(is_array($data)){
                foreach($data as $k => $v){
                    get_group($data[$k], $group, $parent);
                }
                
            }
        } 
    }
}

get_group($array['Классификатор'], $group);
echo '<pre>';
print_r($group);
echo '</pre>';
exit;
 
Страницы: 1
Похожие темы:
Читают тему (гостей: 1, пользователей: 0, из них скрытых: 0)
Новые темыОбъявленияСвободное общение
17:11 Biggico - крипто партнерская сеть | выплаты в BTC, ETH, фиате, | Revenue Share, CPA, CPL офферы 
17:05 31.08.2018 Апдейт Яндекс ИКС 
17:02 "Страница проиндексирована, но ее нет в файле Sitemap" - а она там есть! 
15:29 Это нормальна выдача?? 
15:21 BadBoys.network - Сконвертим Ваш Push Трафик в $$$! 
15:19 Яндекс выдача 26 сентября 2018 
15:14 Блокировка основоного зеркало РКН 
15:48 Новый проект 333ETH по распространению криптовалюты - берет рынок штурмом. 
15:33 UNIN.pro - обмен QIWI,BTC,WEX (+2+5%),EXMO,PM,ADV,Payeer,Yandex,Сбербанк,ВТБ,Альфа,Тинькофф 
15:17 Профессиональное ведение каналов в Ютубе, Белое продвижение, Услуги в соц. сетях 
13:50 Комплексный прогон по трастовым сайтам, статейное размещение. Рост НЧ-СЧ, Тиц-пр. 
13:30 Услуга чертежника и 3D моделирования 
11:15 Верстка, создание, доработка сайтов 
11:04 Копирайт, рерайт, переводы, размножение текстов 
15:39 Детство и спорт 
15:38 Провожу бесплатные аудиты сайтов, консультации, сбор семантических ядер 
15:34 Индексация ссылок в профилях форумов 
15:25 Оценка сайта Помощь. 
15:23 PushAds.Guru - продаём и покупаем PUSH формат 
15:20 Партнерская программа от веб-студии Megagroup.ru. Комиссия до 44% за сайт. 
15:19 E-mail рассылка