php代码实现xml格式转换,PHP实现XML与数据格式进行转换类实例

PHP实现XML与数据格式进行转换类实例

来源:中文源码网    浏览: 次    日期:2018年9月2日

【下载文档:  PHP实现XML与数据格式进行转换类实例.txt 】

(友情提示:右键点上行txt文档名->目标另存为)

PHP实现XML与数据格式进行转换类实例 本文实例讲述了PHP实现XML与数据格式进行转换类。分享给大家供大家参考。具体如下:

'

$parent[$level-1] = &$current;

if (!is_array($current) or (!in_array($tag, array_keys($current)))) { // Insert New tag

$current[$tag] = $result;

if ($attributes_data) $current[$tag . '_attr'] = $attributes_data;

$repeated_tag_index[$tag . '_' . $level] = 1;

$current = &$current[$tag];

} else { // There was another element with the same tag name

if (isset($current[$tag][0])) { // If there is a 0th element it is already an array

$current[$tag][$repeated_tag_index[$tag . '_' . $level]] = $result;

$repeated_tag_index[$tag . '_' . $level]++;

} else { // This section will make the value an array if multiple tags with the same name appear together

$current[$tag] = array($current[$tag], $result); //This will combine the existing item and the new item together to make an array

$repeated_tag_index[$tag . '_' . $level] = 2;

if (isset($current[$tag . '_attr'])) { // The attribute of the last(0th) tag must be moved as well

$current[$tag]['0_attr'] = $current[$tag . '_attr'];

unset($current[$tag . '_attr']);

}

}

$last_item_index = $repeated_tag_index[$tag . '_' . $level]-1;

$current = &$current[$tag][$last_item_index];

}

} elseif ($type == "complete") { // Tags that ends in 1 line ''

// See if the key is already taken.

if (!isset($current[$tag])) { // New Key

$current[$tag] = $result;

$repeated_tag_index[$tag . '_' . $level] = 1;

if ($priority == 'tag' and $attributes_data) $current[$tag . '_attr'] = $attributes_data;

} else { // If taken, put all things inside a list(array)

if (isset($current[$tag][0]) and is_array($current[$tag])) { // If it is already an array...

// ...push the new element into that array.

$current[$tag][$repeated_tag_index[$tag . '_' . $level]] = $result;

if ($priority == 'tag' and $get_attributes and $attributes_data) {

$current[$tag][$repeated_tag_index[$tag . '_' . $level] . '_attr'] = $attributes_data;

}

$repeated_tag_index[$tag . '_' . $level]++;

} else { // If it is not an array...

$current[$tag] = array($current[$tag], $result); //...Make it an array using using the existing value and the new value

$repeated_tag_index[$tag . '_' . $level] = 1;

if ($priority == 'tag' and $get_attributes) {

if (isset($current[$tag . '_attr'])) { // The attribute of the last(0th) tag must be moved as well

$current[$tag]['0_attr'] = $current[$tag . '_attr'];

unset($current[$tag . '_attr']);

}

if ($attributes_data) {

$current[$tag][$repeated_tag_index[$tag . '_' . $level] . '_attr'] = $attributes_data;

}

}

$repeated_tag_index[$tag . '_' . $level]++; //0 and 1 index is already taken

}

}

} elseif ($type == 'close') { // End of tag ''

$current = &$parent[$level-1];

}

}

return($xml_array);

}

// Array to XML

class array2xml {

public $output = "\n";

public $sub_item = array();

public function __construct($array) {

$sub_item = array();

$this->output .= $this->xmlmake($array);

}

public function xmlmake($array, $fk = '') {

$xml = '';

global $sub_item;

foreach ($array as $key => $value) {

if (is_array($value)) {

if (is_numeric($key)) {

$this->sub_item=array_merge($this->sub_item,array($fk));

$xml .= "" . $this->xmlmake($value, $key) . "{$fk}>";

} else {

$xml .= "" . $this->xmlmake($value, $key) . "{$key}>";

}

} else {

$xml .= "{$value}{$key}>\n";

}

}

return $xml;

}

public function output(){

foreach($this->sub_item as $t){

$this->output = str_replace("","",$this->output);

$this->output = str_replace("{$t}>{$t}>","{$t}>",$this->output);

}

return $this->output;

}

}希望本文所述对大家的php程序设计有所帮助。

亲,试试微信扫码分享本页! *^_^*

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值