Add XML processing script to fetch and transform product data
This commit is contained in:
93
interblue.pl/index.php
Normal file
93
interblue.pl/index.php
Normal file
@@ -0,0 +1,93 @@
|
||||
<?php
|
||||
// Włącz wyświetlanie błędów dla celów debugowania
|
||||
error_reporting(E_ALL);
|
||||
ini_set('display_errors', 1);
|
||||
|
||||
// Definiowanie źródłowego URL pliku XML i nazwy pliku docelowego
|
||||
$source_url = 'https://sollux-lighting.com/product_feed/news072024/XML_polski_PLN_new_07_2024.xml';
|
||||
$target_file = 'new_products.xml';
|
||||
|
||||
// Pobranie i załadowanie źródłowego pliku XML
|
||||
$source_xml = simplexml_load_file($source_url);
|
||||
|
||||
if ($source_xml === false) {
|
||||
die('Błąd podczas ładowania źródłowego pliku XML.');
|
||||
}
|
||||
|
||||
// Utworzenie nowego dokumentu XML z korzeniem <products>
|
||||
$xml = new SimpleXMLElement('<?xml version="1.0" encoding="UTF-8"?><products></products>');
|
||||
|
||||
// Definicja nazw elementów, które zawierają ceny
|
||||
$price_fields = [
|
||||
'cena_detaliczna_brutto_pln',
|
||||
// Dodaj tutaj inne pola cen, jeśli istnieją
|
||||
// 'cena_inna_field',
|
||||
];
|
||||
|
||||
// Iteracja przez każdy produkt w źródłowym pliku XML
|
||||
foreach ($source_xml->product as $product) {
|
||||
// Tablica do przechowywania adresów URL obrazów
|
||||
$images = [];
|
||||
|
||||
// Iteracja przez wszystkie dzieci elementu <product>
|
||||
foreach ($product->children() as $child) {
|
||||
$child_name = $child->getName();
|
||||
|
||||
// Sprawdzenie, czy element jest jednym z obrazów (image_1, image_2, ..., image_25)
|
||||
if (preg_match('/^image_\d+$/', $child_name)) {
|
||||
$url = trim((string)$child);
|
||||
|
||||
// Dodanie niepustego URL do tablicy obrazów
|
||||
if (!empty($url)) {
|
||||
$images[] = $url;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Utworzenie nowego elementu <product> w nowym XML
|
||||
$new_product = $xml->addChild('product');
|
||||
|
||||
// Ponowna iteracja przez dzieci oryginalnego <product>, aby skopiować nieobrazkowe elementy
|
||||
foreach ($product->children() as $child) {
|
||||
$child_name = $child->getName();
|
||||
|
||||
// Pomijanie elementów obrazów
|
||||
if (!preg_match('/^image_\d+$/', $child_name)) {
|
||||
// Pobranie wartości elementu
|
||||
$value = (string)$child;
|
||||
|
||||
// Sprawdzenie, czy element jest polem cenowym
|
||||
if (in_array($child_name, $price_fields)) {
|
||||
// Zamiana kropki na przecinek w wartości ceny
|
||||
$value = str_replace('.', ',', $value);
|
||||
}
|
||||
|
||||
// Dodanie elementu do nowego <product>
|
||||
$new_child = $new_product->addChild($child_name);
|
||||
|
||||
// Sprawdzenie, czy zawartość to HTML i potrzeba CDATA
|
||||
// Jeśli chcesz zachować tagi HTML, możesz użyć CDATA
|
||||
if (strpos($child_name, 'opis_krotki_html') !== false || strpos($child_name, 'opis_dlugi_korzysci_html') !== false) {
|
||||
$node = dom_import_simplexml($new_child);
|
||||
$no = $node->ownerDocument;
|
||||
$node->appendChild($no->createCDATASection($value));
|
||||
} else {
|
||||
$new_child[0] = htmlspecialchars($value);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Połączenie wszystkich adresów URL obrazów w jeden ciąg oddzielony przecinkami
|
||||
$images_str = implode(',', $images);
|
||||
|
||||
// Dodanie nowego elementu <images> do nowego <product>
|
||||
$new_product->addChild('images', htmlspecialchars($images_str));
|
||||
}
|
||||
|
||||
// Zapisanie nowego pliku XML na serwerze
|
||||
if($xml->asXML($target_file)) {
|
||||
echo "Nowy plik XML został utworzony: $target_file";
|
||||
} else {
|
||||
echo "Wystąpił błąd podczas zapisywania nowego pliku XML.";
|
||||
}
|
||||
?>
|
||||
Reference in New Issue
Block a user