duanpiyao2734 2011-05-14 06:38
浏览 88


I am trying to find out how to merge the FIPS part of this XML file into one php variable with SimpleXML.

a sample xml file I'm trying to use is at http://codepad.org/MQeR2VBZ

basically i want a variable with "001033,001077" in it (without the quotes"

I'm new to PHP and this is my first time using stackoverflow so please forgive me if I'm full of fail

  • 写回答

2条回答 默认 最新

  • doulun5683 2011-05-14 08:24

    You can solve this easily with XPath.

    XPath lets you query for nodes in the document in almost any possible combination. To query for the geocode value that is preceded by a valueName element with the content FIPS6, you can use this query:

    /alert/info/area/geocode/value[preceding-sibling::valueName = "FIPS6"]

    However, the document has a default namespace for the alert element (as indicated by the xmlns attribute). By default, SimpleXml will not be able to access any namespaced nodes in the document via XPath until we tell it the namespace via registerXPathNamespace and prefix any elements in the query with an arbitrary prefix.

    The result of the XPath will be an array containing SimpleXmlElements. When you cast a SimpleXmlElement to string (or use it in a string context), it will return it's nodeValue, which is the values you actually want to combine, so you can simply call implode on the resulting array to combine the values into a string.

    Code (demo)

    $alert = simplexml_load_file('http://…');
    $alert->registerXPathNamespace('a', 'urn:oasis:names:tc:emergency:cap:1.1');
    $fipsValues = implode(',', $alert->xpath(
            preceding-sibling::a:valueName = "FIPS6"
    print_r($fipsValues); // will contain "001033,001077"
    本回答被题主选为最佳回答 , 对您是否有帮助呢?



  • ¥15 FIR滤波器算法设计与实现(利用库函数firdec()
  • ¥15 利用单片机产生正弦信号,来测量差分放大电路放大倍数和共模放大倍数的思路和仿真
  • ¥66 定制开发肯德基自动化网站下单软件
  • ¥20 vscode虚拟环境依赖包未安装
  • ¥15 odoo17关于owl开发js代码问题
  • ¥15 光纤中多普勒频移公式的推导
  • ¥15 怎么制作一个人脸识别门禁系统
  • ¥20 大华dss监控平台网络关闭登不进去
  • ¥15 请使用蚁群算法解决下列问题,并给出我完整的代码
  • ¥20 关于php录入完成后,批量更新数据库