$str = file_get_contents(“http://192.168.50.23/cgi-bin/getvpdnalarmbyxml.py”);

$xmlObject=simplexml_load_string($str);

这样获取的xmlObject是SimpleXMLElement类型的

SimpleXMLElement Object

(

[@attributes] => Array

(

[name] => vpdnalam

[website] => http://192.168.50.23

)

[ggsn43alarm1] => SimpleXMLElement Object

(

[Happentime] =>

            2014-04-21 11:19:02

[Netype] =>

            GGSN43

[Severity] =>

            4

        ……

需要将SimpleXMLElement转换为数组类型进行排序

http://www.binarytides.com/convert-simplexml-object-to-array-in-php/ 讲解了格式转换方式

$xml_array = json_decode( json_encode($xmlObject) , 1); //将simpleXMLElement转换为了数组格式

unset($xml_array[‘@attributes&apos’]); //删除数组第一个属性

最后排序 $xml_array_sort = multi_array_sort($xml_array,’Severity’);//按照Severity排序

function multi_array_sort($multi_array,$sort_key,$sort=SORT_ASC){
          if(is_array($multi_array)){
                   foreach ($multi_array as $row_array){
                             if(is_array($row_array)){
                                      $key_array[] = $row_array[$sort_key];
                                      print_r($key_array);
                             }
                             else{
                                      return false;
                                      }
                   }
          }
          else{
                   return false;
                  
          }
          array_multisort($key_array,$sort,$multi_array);
          //print_r($multi_array."multi_array");
          return $multi_array;
}

—————————————-

array_multisort

array_multisort — 对多个数组或多维数组进行排序

说明 

array_multisort() 可以用来一次对多个数组进行排序,或者根据某一维或多维对多维数组进行排序。

关联(string)键名保持不变,但数字键名会被重新索引。

排序顺序标志:

o    SORT_ASC 按照上升顺序排序

o    SORT_DESC 按照下降顺序排序

排序类型标志:

o    SORT_REGULAR 将项目按照通常方法比较

o    SORT_NUMERIC 将项目按照数值比较

o    SORT_STRING 将项目按照字符串比较

每个数组之后不能指定两个同类的排序标志。每个数组后指定的排序标志仅对该数组有效在此之前为默认值SORT_ASC  SORT_REGULAR

输入数组被当成一个表的列并以行来排序——这类似于 SQL ORDER BY子句的功能。第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话就按照下一个输入数组中相应值的大小来排序,依此类推。

arr

要排序的一个 array

arg

接下来的每个参数可以是另一个 array 或者是为之前 array 排序标志选项参数: SORT_ASCSORT_DESC,SORT_REGULARSORT_NUMERICSORT_STRING.


Additional arg's.

返回值 

成功时返回 TRUE
或者在失败时返回 FALSE

范例 

Example #1 Sorting multiple arrays

<?php
$ar1 = array(10
1001000);
$ar2 = array(1
324);
array_multisort($ar1
$ar2);

var_dump($ar1);
var_dump($ar2);
?>


array(4) {

[0]=> int(0)

[1]=> int(10)

[2]=> int(100)

[3]=> int(100)

}

array(4) {

[0]=> int(4)

[1]=> int(1)

[2]=> int(2)

[3]=> int(3)

}

Example #2 排序多维数组

<?php
$ar = array(
       array(“10”
11100100“a”),
       array(   1
,  2“2”,   3,   1)
      );
array_multisort($ar[
0], SORT_ASCSORT_STRING,
                
$ar[1], SORT_NUMERICSORT_DESC);
var_dump($ar);
?>


本例中在排序后,第一个数组将变成 “10”10010011“a”(被当作字符串以升序排列)。第二个数组将包含 1, 3, “2”, 2, 1(被当作数字以降序排列)。

array(2) {

[0]=> array(5) {

[0]=> string(2) “10”

[1]=> int(100)

[2]=> int(100)

[3]=> int(11)

[4]=> string(1) “a”

}

[1]=> array(5) {

[0]=> int(1)

[1]=> int(3)

[2]=> string(1) “2”

[3]=> int(2)

[4]=> int(1)

}

}

Example #3 对数据库结果进行排序

本例中 data 数组中的每个单元表示一个表中的一行。这是典型的数据库记录的数据集合。

例子中的数据如下:

volume | edition

——-+——–

67 | 2

86 | 1

85 | 6

98 | 2

86 | 6

67 | 7

数据全都存放在名为 data 的数组中。这通常是通过循环从数据库取得的结果,例如 mysql_fetch_assoc()

<?php
$data[] = array(‘
volume’ => 67‘edition’ => 2);
$data[] = array(‘volume’ => 86
‘edition’ => 1);
$data[] = array(‘volume’ => 85
‘edition’ => 6);
$data[] = array(‘volume’ => 98
‘edition’ => 2);
$data[] = array(‘volume’ => 86
‘edition’ => 6);
$data[] = array(‘volume’ => 67
‘edition’ => 7);
?>


本例中将把 volume 降序排列,把 edition 升序排列。

现在有了包含有行的数组,但是 array_multisort() 需要一个包含列的数组,因此用以下代码来取得列,然后排序。


<?php
// 
取得列的列表
foreach ($data as $key => $row) {
    $volume[$key]  = $row[‘volume’;];
    $edition[$key] = $row[‘edition’];
}

// 将数据根据 volume 降序排列,根据 edition 升序排列
//  $data 作为最后一个参数,以通用键排序
array_multisort($volumeSORT_DESC$editionSORT_ASC$data);
?>


数据集合现在排好序了,结果如下:

volume | edition

——-+——–

98 | 2

86 | 1

86 | 6

85 | 6

67 | 2

67 | 7

Example #4 不区分大小写字母排序

SORT_STRING  SORT_REGULAR 都是区分大小写字母的,大写字母会排在小写字母之前。

要进行不区分大小写的排序,就要按照原数组的小写字母拷贝来排序。

<?php
$array = array(‘Alpha’
‘atomic’‘Beta’‘bank’);
$array_lowercase array_map(‘strtolower’
$array);

array_multisort($array_lowercaseSORT_ASCSORT_STRING$array);

print_r($array);
?>


以上例程会输出:

Array

(

[0] => Alpha

[1] => atomic

[2] => bank

[3] => Beta

)

【译者注】本函数相当有用,为有助于理解,请再看下面这个例子:

Example #5 名次排列

<?php
$grade = array(“score” => array(70
9570.060“70”),
               “name” => array(“Zhang San”
“Li Si”“Wang Wu”,
                               
“Zhao Liu”“Liu Qi”));
array_multisort($grade[“score”], SORT_NUMERIC
SORT_DESC,
                
// 将分数作为数值,由高到低排序
                
$grade[“name”], SORT_STRINGSORT_ASC);
                // 
将名字作为字符串,由小到大排序
var_dump($grade);
?>


以上例程会输出:

array(2) {

[“score”]=>

array(5) {

[0]=>

int(95)

[1]=>

string(2) “70”

[2]=>

float(70)

[3]=>

int(70)

[4]=>

int(60)

}

[“name”]=>

array(5) {

[0]=>

string(5) “Li Si”

[1]=>

string(6) “Liu Qi”

[2]=>

string(7) “Wang Wu”

[3]=>

string(9) “Zhang San”

[4]=>

string(8) “Zhao Liu”

}

}

本例中对包含成绩的数组 $grade 按照分数(score)由高到低进行排序,分数相同的人则按照名字(name)由小到大排序。排序后李四 95 分为第一名,赵六 60 分为第五名没有异议。张三、王五和刘七都是 70 分,他们的名次则由其姓名的字母顺序排列,Liu 在前,Wang 在后而 Zhang 在最后。为了区别,三个 70 分分别用了整数,浮点数和字符串来表示,可以在程序输出中清楚地看到它们排序的结果。

 
 



分类: PHP

发表评论

电子邮件地址不会被公开。 必填项已用*标注