Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/288.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 根据SimpleXMLElement文档中的值对数组进行Alpha排序_Php_Arrays_Sorting_Simplexml_Usort - Fatal编程技术网

Php 根据SimpleXMLElement文档中的值对数组进行Alpha排序

Php 根据SimpleXMLElement文档中的值对数组进行Alpha排序,php,arrays,sorting,simplexml,usort,Php,Arrays,Sorting,Simplexml,Usort,我正在从sba.gov的API中获取一份城市列表。使用SimpleXML,我有以下代码: $city_url = 'http://api.sba.gov/geodata/city_links_for_state_of/ca.xml'; $city_xml = simplexml_load_file($city_url) or die("feed not loading"); $city_array = array(); foreach($city_xml a

我正在从sba.gov的API中获取一份城市列表。使用SimpleXML,我有以下代码:

$city_url = 'http://api.sba.gov/geodata/city_links_for_state_of/ca.xml';
    $city_xml = simplexml_load_file($city_url) or die("feed not loading");      
    $city_array = array();

    foreach($city_xml as $city) {
        $city_array[] = $city->name;
    }
    //sort($city_array);
    //usort($city_array, function($a, $b){ return strcmp($a["name"], $b["name"]); });
    print_r($city_array);
XML格式如下所示:

<sites count="431">
<site>
<county_name>Monterey</county_name>
<description nil="true"/>
<feat_class>Populated Place</feat_class>
<feature_id>1536</feature_id>
<fips_class>C1</fips_class>
<fips_county_cd>53</fips_county_cd>
<full_county_name>Monterey County</full_county_name>
<link_title nil="true"/>
<url>http://www.ci.marina.ca.us/</url>
<name>Marina</name>
<primary_latitude>36.68</primary_latitude>
<primary_longitude>-121.8</primary_longitude>
<state_abbreviation>CA</state_abbreviation>
<state_name>California</state_name>
</site>
<site>
<county_name>Contra Costa</county_name>
<description nil="true"/>
<feat_class>Populated Place</feat_class>
<feature_id>1537</feature_id>
<fips_class>C1</fips_class>
<fips_county_cd>13</fips_county_cd>
<full_county_name>Contra Costa County</full_county_name>
<link_title nil="true"/>
<url>http://www.cityofmartinez.org/</url>
<name>Martinez</name>
<primary_latitude>38.01</primary_latitude>
<primary_longitude>-122.13</primary_longitude>
<state_abbreviation>CA</state_abbreviation>
<state_name>California</state_name>
</site>
</sites>

蒙特利
人口稠密的地方
1536
C1
53
蒙特利县
http://www.ci.marina.ca.us/
玛丽娜
36.68
-121.8
加利福尼亚州
加利福尼亚
康特拉科斯塔酒店
人口稠密的地方
1537
C1
13
康特拉科斯塔县
http://www.cityofmartinez.org/
马丁内斯
38.01
-122.13
加利福尼亚州
加利福尼亚
我试图从XML创建一个数组,然后按name元素对数组进行排序,这样就可以按alpha顺序输出表单下拉列表


谢谢你抽出时间

问题在于,您正在构建
simplexmlement对象的数组,而不是可排序的字符串。要解决问题,只需在向数组添加元素时强制转换它们:

$city_array[] = (string) $city->name;
sort()应该是有效的。您的打印输出是什么?