使用PHP进行Xpath日期比较
我有一个xml文件使用PHP进行Xpath日期比较,php,xml,xpath,Php,Xml,Xpath,我有一个xml文件 <?xml version="1.0" encoding="UTF-8" ?> <?xml-stylesheet type="text/xsl" href="test1.xsl"?> <products> <node> <node> <dist_value> <node> 55 </node>
<?xml version="1.0" encoding="UTF-8" ?>
<?xml-stylesheet type="text/xsl" href="test1.xsl"?>
<products>
<node>
<node>
<dist_value>
<node> 55 </node>
<node> 59 </node>
<node> 72 </node>
</dist_value>
<reg_str_dt>
<node> 2013-08-03 17:29:00 </node>
</reg_str_dt>
<product_id> 1 </product_id>
</node>
</node>
<node>
<node>
<dist_value>
<node> 72 </node>
<node> 19 </node>
<node> 49 </node>
</dist_value>
<reg_str_dt>
<node> 2013-10-25 17:29:00 </node>
</reg_str_dt>
<product_id> 2 </product_id>
</node>
</node>
<node>
<node>
<dist_value>
<node> 12 </node>
<node> 548 </node>
<node> 112 </node>
</dist_value>
<reg_str_dt>
<node> 2013-08-12 17:29:00 </node>
</reg_str_dt>
<name> test </name>
<product_id> 3 </product_id>
</node>
</node>
</products>
55
59
72
2013-08-03 17:29:00
1.
72
19
49
2013-10-25 17:29:00
2.
12
548
112
2013-08-12 17:29:00
试验
3.
我编写了这个PHP代码来比较日期
$my_date = '2013-09-01';
$xml = new DOMDocument();
$xml->load('product.xml');
$xpd = new DOMXPath($xml);
false&&$result_data = new DOMElement();
$result = $xpd->query("//node[reg_str_dt[(translate(node,'-','') > translate($my_date, '-', '') ]/*");
foreach($result as $result_data){
echo $result_data->nodeName ." => ". $result_data->nodeValue ."<br/>";
}
$my_date='2013-09-01';
$xml=newdomdocument();
$xml->load('product.xml');
$xpd=newdomxpath($xml);
false&$result_data=new DOMELENT();
$result=$xpd->query(//node[reg_str_dt[(translate(node,'-','')>translate($my_date,'-',''))/*);
foreach($result作为$result\u数据){
echo$result\u data->nodeName。“=>”$result\u data->nodeValue。“
”;
}
但是这个代码不起作用
在输出中,它将返回产品2的数据-
<?php
$my_date = '2013-09-01';
$xml = new DOMDocument();
$xml->load('product.xml');
$xpd = new DOMXPath($xml);
false&&$result_data = new DOMElement();
$result = $xpd->query('//node[translate(translate(translate("2013-09-01 17:20:19", "-", "")," ",""),":","") > translate(translate(translate(node/reg_str_dt/node,"-","")," ",""),":","")]/*');
foreach($result as $result_data){
echo $result_data->nodeName." => ". $result_data->nodeValue ."<br/>";;
}
?>
load('product.xml');
$xpd=newdomxpath($xml);
false&$result_data=new DOMELENT();
$result=$xpd->query('//node[translate(translate(translate)(“2013-09-01 17:20:19”、“-”、“)、”、“:”、”)>translate(translate(translate(节点/reg_str_dt/node,“-”、“,”)、“:”、“)/*));
foreach($result作为$result\u数据){
echo$result_data->nodeName。“=>”$result_data->nodeValue。“
”;;
}
?>
我真想知道为什么你认为它可以工作。这不是比较xpath中字符串和数字(因为没有数字)的正确方法。