- 张映
- 男
- 28
- tank
- 男
- 28
1)DOMDocument读取xml
- $doc = new DOMDocument();
- $doc->load('person.xml'); //读取xml文件
- $humans = $doc->getElementsByTagName_r( "humans" ); //取得humans标签的对象数组
- foreach( $humans as $human )
- {
- $names = $human->getElementsByTagName_r( "name" ); //取得name的标签的对象数组
- $name = $names->item(0)->nodeValue; //取得node中的值,如
- $sexs = $human->getElementsByTagName_r( "sex" );
- $sex = $sexs->item(0)->nodeValue;
- $olds = $human->getElementsByTagName_r( "old" );
- $old = $olds->item(0)->nodeValue;
- echo "$name - $sex - $old\n";
- }
- ?>
2)simplexml读取xml
- $xml_array=simplexml_load_file('person.xml'); //将XML中的数据,读取到数组对象中
- foreach($xml_array as $tmp){
- echo $tmp->name."-".$tmp->sex."-".$tmp->old."
"; - }
- ?>
3)用php正则表达式来记取数据
- $xml = "";
- $f = fopen('person.xml', 'r');
- while( $data = fread( $f, 4096 ) ) {
- $xml .= $data;
- }
- fclose( $f );
- // 上面读取数据
- preg_match_all( "/\(.*?)\<\/humans\>/s", $xml, $humans ); //匹配最外层标签里面的内容
- foreach( $humans[1] as $k=>$human )
- {
- preg_match_all( "/\(.*?)\<\/name\>/", $human, $name ); //匹配出名字
- preg_match_all( "/\(.*?)\<\/sex\>/", $human, $sex ); //匹配出性别
- preg_match_all( "/\(.*?)\<\/old\>/", $human, $old ); //匹配出年龄
- }
- foreach($name[1] as $key=>$val){
- echo $val." - ".$sex[$key][1]." - ".$old[$key][1]."
" ; - }
- ?>
4)xmlreader来读取xml数据
- $reader = new XMLReader();
- $reader->open('person.xml'); //读取xml数据
- $i=1;
- while ($reader->read()) { //是否读取
- if ($reader->nodeType == XMLReader::TEXT) { //判断node类型
- if($i%3){
- echo $reader->value; //取得node的值
- }else{
- echo $reader->value."
" ; - }
- $i++;
- }
- }
- ?>
三,小结
读取xml的方法很多,简单举几个。上面四种方法都是可以把标签中的数据读出来,张映.但是他们的测重点不同,前三种方法的读取xml的function的设计重点,是为了读取标签中的值,相当于jquery中的text()方法,而xmlreader呢他就不太一样,他的重点不在读取标签中的值,而读取标签的属性,把要传送的数据,都放在属性中(不过我上面写的那个方法还是取标签中的值,因为xml文件已经给定了,我就不想在搞xml文件出来了)。
举个例子解释一下,
xmlreader的设计重点是为了读data里面的name sex old的值,而读取的内容就比较麻烦了。他相当于jquery中attr(”);这个东西。 |