Skip to main content

Different ways of parsing xml data

Here i show the example for parsing xml data, using jquery, javascript and php.
Here is a sample xml file, we are using, msg.xml:

<messages>
    <message>
    <name>Sam</name>   
    <msg>Hi Anna</msg>
    </message>
    <message>
    <name>Kelly</name>
    <msg>Hi Anna</msg>
    </message>
    <message>
    <name>Sam</name>
    <msg>Hi Anna</msg>
    </message>
    <message>
    <name>Sam</name>
    <msg>Hello Anna</msg>
    </message>
    <message>
    <name>Kelly</name>
    <msg>Anna</msg>
    </message>
</messages>

The source code:

<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js" type="text/javascript"></script>
<script type="text/javascript">
function loadXMLDoc(dname)
{
if (window.XMLHttpRequest)
  {
  xhttp=new XMLHttpRequest();
  }
else
  {
  xhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
xhttp.open("GET",dname,false);
xhttp.send();
return xhttp.responseXML;
}

xmlDoc=loadXMLDoc("msg.xml");
x=xmlDoc.getElementsByTagName("name")[0];
y=x.childNodes[0];
document.write(y.nodeValue);
document.write("<br>");

var xml = "<music><album>Michael Jackson</album></music>";
var result = $(xml).find("album").text();
document.write(result);
document.write("<br>");
</script>
</head>
<body>
<?php
$xml = "<books>
<book>Patterns of Enterprise Application Architecture</book>
<book>Design Patterns: Elements of Reusable Software Design</book>
<book>Clean Code</book>
</books>";

$dom = new DOMDocument;
$dom->loadXML($xml);
$books = $dom->getElementsByTagName('book');

foreach ($books as $book) {
    echo $book->nodeValue.'<br>';
}
?>
</body>
</html>

Output:
Sam
Michael Jackson
Patterns of Enterprise Application Architecture
Design Patterns: Elements of Reusable Software Design
Clean Code

Comments

Popular posts from this blog

Joomla validate chrono forms using jquery

It is a common practice to use Chrono forms in our joomla site to setup various forms in the site, be it a contact us form, submit a ticket form, or whatever. I have set the option "validate form" to "No" under chronoform settings in admin panel, and also preferred to not include any js or css files. For validating the chrono forms, i prefer jquery. So first lets add jquery support in our joomla. It is quite simple: 1. Download jquery.js and jquery_min.js (1.4.2 version is enough) and place them in media/system/js folder of your joomla. 2. Edit libraries->joomla->html->html->behavior.php, and add the following function below the mootools() function: function jQuery($debug = null)     {         static $loaded;         global $mainframe;         // Only load once         if ($loaded) {    ...

joomla remove category name in url

-) If anyone is using the lyftenbloggie component, and want to remove the component name and category title from the sef url, follow this hack: (Note: You also need to install the lyftenbloggie extension for ARTIO SEF) Under components/com_sef/joomsef.php, After this code: $location = array();         foreach ($title as $titlePart) {             if (strlen($titlePart) == 0) continue;             $location[] = JoomSEF::_titleToLocation($titlePart);         } Just add this code: if($location[0] == 'lyftenbloggie')         {         $temp_sef = end($location);         $location = array();            $location[] = $temp_sef;         ...

php get content between tags

This involves parsing the dom document. <?php function getTextBetweenTags($tag, $html) {     $dom = new domDocument;     @$dom->loadHTML($html);         $dom->preserveWhiteSpace = false;     $content = $dom->getElementsByTagname($tag);     $out = array();         foreach ($content as $item)     {         $out[] = $item->nodeValue;     }     return $out; } $xhtml = '<tag>abc def</tag><tag>123 456</tag>'; $content2 = getTextBetweenTags('tag', $xhtml); foreach( $content2 as $item ) {     echo $item.'<br />'; } ?> Output: abc def 123 456