看着标题说实在的有些小绕口,许久不写文章了,但是在身边有许多用到的小知识点点,还是记录一下。
今天在处理一个商家接口时,返回数据级其有意思,在产生定单信息时候,一个订单包含多个商品的时候XML的描述大体是这样的。
例如:
<orders> <row1> <order_time>2014-01-07 16:06:49</order_time> <item_name>Verera维芙雅 祛痘控油水100ml</item_name> <ext>E100020402|ad12123</ext> <order_id>20140107712606</order_id> <order_updtime>2014-01-07 16:06:49</order_updtime> </row1> <row2> <order_time>2014-01-07 16:06:49</order_time> <item_name>Verera维芙雅 祛痘控油水100ml</item_name> <ext>E100020402|ad12123</ext> <order_id>20140107712606</order_id> <order_updtime>2014-01-07 16:06:49</order_updtime> </row2> <row3> <order_time>2014-01-07 16:06:49</order_time> <item_name>Verera维芙雅 祛痘控油水100ml</item_name> <ext>E100020402|ad12123</ext> <order_id>20140107712606</order_id> <order_updtime>2014-01-07 16:06:49</order_updtime> </row3> </orders>
这是一个局部的XML,其实看到这样一个XML去解析并非难事,但是对于开发系统而言,单独去解析有些浪费。
其实我原三就是将XML反序列化为指定Model就行了,这样很容易做到,只是将Model属性做成XmlRoot 或者xmlelament xmlAttribute就行了,要看具体是什么属性。
但是对于Row+Number,呃,行不通了。于是我想到了正则替换。
在我的调试下的确可以实现,今天就是为了记录正则替换,
Regex regex =new Regex(@"<row(\d+)>(.*?)</row\1>"); string replaceAfter = regex.Replace(args,@"<row>$2</row>");
非常方便,这种替换在Net里面叫后向引用替换,大家可以尝试一下。