2011-06-16 2 views
0

Я новичок в php. Как стажер, я должен заполнить базу данных в MySQL, используя данные из XML-файлов. Проблема в том, что эти файлы XML не всегда имеют одинаковый формат. Итак, я пишу код в php5, и я хотел бы знать, как подсчитать количество вхождений определенного дочернего элемента в тег. В моем XML-файле я хочу подсчитать количество показов дочерних элементов в узле «ing-div». Некоторые файлы XML могут иметь один, два или более узла «ing-div». Любая помощь?Как подсчитать количество вхождений ребенка в тег?

здесь является XML файл

<?xml version="1.0" encoding="UTF-8" ?> 
- <recipeml version="0.5"> 
- <recipe> 
- <head> 
    <title>100 Whole Wheat Bread for Bread Machine</title> 
- <categories> 
    <cat>Breadmaker</cat> 
    <cat>Breads</cat> 
    </categories> 
    <yield>8</yield> 
    </head> 
- <ingredients> 
- <ing-div> 
    <title>REGULAR LOAF</title> 
- <ing> 
- <amt> 
    <qty>1</qty> 
    <unit>cup</unit> 
    </amt> 
    <item>Water</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>2 1/2</qty> 
    <unit>cups</unit> 
    </amt> 
    <item>Wheat bread flour</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>1 1/4</qty> 
    <unit>tablespoons</unit> 
    </amt> 
    <item>Dry milk</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>1</qty> 
    <unit>teaspoon</unit> 
    </amt> 
    <item>Salt</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>1 1/2</qty> 
    <unit>tablespoons</unit> 
    </amt> 
    <item>Butter</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>1 1/4</qty> 
    <unit>tablespoons</unit> 
    </amt> 
    <item>Honey</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>1</qty> 
    <unit>tablespoon</unit> 
    </amt> 
    <item>Gluten</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>2</qty> 
    <unit>teaspoons</unit> 
    </amt> 
    <item>Molasses</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>1 1/2</qty> 
    <unit>teaspoons</unit> 
    </amt> 
    <item>Fast-Rise yeast *** OR ***</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>2</qty> 
    <unit>teaspoons</unit> 
    </amt> 
    <item>Active-Dry yeast</item> 
    </ing> 
    </ing-div> 
- <ing-div> 
    <title>LARGE LOAF</title> 
- <ing> 
- <amt> 
    <qty>1 1/2</qty> 
    <unit>cups</unit> 
    </amt> 
    <item>+ 2 tb Water</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>3 3/4</qty> 
    <unit>cups</unit> 
    </amt> 
    <item>Wheat bread flour</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>2</qty> 
    <unit>tablespoons</unit> 
    </amt> 
    <item>Dry milk</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>1 1/2</qty> 
    <unit>teaspoons</unit> 
    </amt> 
    <item>Salt</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>2</qty> 
    <unit>tablespoons</unit> 
    </amt> 
    <item>Butter</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>2</qty> 
    <unit>tablespoons</unit> 
    </amt> 
    <item>Honey</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>1 1/2</qty> 
    <unit>tablespoons</unit> 
    </amt> 
    <item>Gluten</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>1</qty> 
    <unit>tablespoon</unit> 
    </amt> 
    <item>Molasses</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>2 1/8</qty> 
    <unit>teaspoons</unit> 
    </amt> 
    <item>Fast-Rise yeast *** OR ***</item> 
    </ing> 
- <ing> 
- <amt> 
    <qty>3</qty> 
    <unit>teaspoons</unit> 
    </amt> 
    <item>Active-Dry yeast</item> 
    </ing> 
    </ing-div> 
    </ingredients> 
- <directions> 
    <step>The trick to making 100% whole wheat bread in your machine is an extra knead, which gives the yeast and gluten a second chance to create a lighter loaf. When your first knead cycle is completed, simply reset the machine and start again. Some manufacturers produce home bakeries with a whole wheat cycle; if your machine doesn't have one, this start- again method works as an easy alternative. SUCCESS HINTS: The gluten gives the whole wheat flour the structure necessary for a good loaf. If your market doesn't stock wheat gluten, try your local health food store. Remember the extra knead. It's especially important in 100% whole wheat bread. Because of the extra knead, us this recipe only on the regular bake cycle. CALORIES: 125 PROTEIN: 14% CHOLESTEROL: 3.98mg CARBOHYDRATES: 73% SODIUM: 218mg FAT: 13% Posted to Bakery-Shoppe Digest V1 #410 by [email protected] (Serge Cyr) on Nov 23, 1997</step> 
    </directions> 
    </recipe> 
    </recipeml> 

и это часть кода, где я пытаюсь подсчитать количество вхождений «ИНГ» в «ИНГ-DIV»

$xml = simplexml_load_file($file); 
$ing_elem = new SimpleXMLElement($xml); 
printf("%d ing.\n", $ing_elem->{'ing-div'}->count()); 

но это не работает вообще. У меня есть сообщение об ошибке:

Фатальная ошибка: Uncaught исключение 'Exception' с сообщением 'Строка не может быть разобран, как XML' в C: \ WAMP \ WWW \ PhP \ XML Папка \ New_Load_All_Files_1.php на линии 115

anny предложения?

Большое вам спасибо за ваше время и вашу помощь.

T3000

+1

Вы уверены, что вы загружаете xml правильно? Ошибка, которую вы получаете, означает, что Simple XML не может читать/анализировать XML-файл. Поскольку он написан, он ожидает, что '$ file' будет допустимым файловым пути к XML-файлу. Вы уверены, что это правильно? Если да, уверены ли вы, что xml? – bejonbee

ответ

0
$xml = new DOMDocument(); 
$xml->load(path/to/file); 
$xpath = new DOMXPath($xml); 
$ingdiv = $xpath->query("/recipeml/recipe/ingredients/ing-div"); 
$length = $ingdiv->length; 
// iterate over all <ing-div> from last to first 
while($length--) 
{ 
    // number of <ing> in the specific <ing-div> 
    print $xpath->query("ing", $ingdiv->item($length))->length; 
} 

Edit:

Вы не должны скопировать & Вставить отформатированный вывод из браузера.

<?xml version="1.0" encoding="UTF-8" ?> 
- <recipeml/> 

Это искаженный XML. XML не может иметь текст за пределами корневого узла.

0

Я не думаю, что вам нужна следующая строка:

$ing_elem = new SimpleXMLElement($xml); 

, так как вы используете simplexml_load_file ($ файл) для создания объекта SimpleXmlElement

Таким образом, ваш объект SimpleXML может быть создан только с помощью этого линия:

$ing_elem = simplexml_load_file($file); 

Вы можете использовать следующий фрагмент кода, чтобы получить более подробную информацию об ошибках, которые могут возникнуть:

libxml_use_internal_errors(true); 
$ing_elem = simplexml_load_file($file); 
if (!$ing_elem) { 
    echo "Failed loading XML\n"; 
    foreach(libxml_get_errors() as $error) { 
     echo "\t", $error->message; 
    } 
} 
+0

, но если idelete строка $ ing_elem = новый SimpleXMLElement ($ xml); у меня будет проблема со следующей строкой, потому что моя переменная $ ing_elem больше не будет определена. – T3000

Смежные вопросы