正则表达式搭配js轻松处理json文本方便而老古


Posted in Javascript onFebruary 17, 2013

很多群里的朋友经常聊到如何解析Json,通常很多人都会搬出他们珍藏的dll出来,比如Newtonsoft.json.dll,litjson.dll等等。互相吹嘘这些动态链接库的功能如何如何了得,依我看,要解析轻量化类型json,用.net自带的类库就可以胜任了。但是,有一种看起来更方便的老古董——正则表达式,处理json是绰绰有余。

Json(JavaScript Object Notation)作为当今互联网最为一种流行的,超越语言的网络数据交换格式,可以说是“肉多骨少”的一种类型,在网络传输方面大有赶超xml作为传统传输格式的地位,其在REST架构上的应用随着腾讯,淘宝等巨型网络公司的推波助澜,而成为程序员追捧的理想格式。

然而,虽然json在javascript里解析起来轻而易举,但是在.net里却没那么容易。即使微软在.NET Framework 3.5中提供了一个JSON对象的序列化工具(System.Web.Script.Serialization.JavaScriptSerializer),但其本身的强类型属性,让人望而却步。

还好,有正则表达式!

正则表达式

首先申明一下,正则表达式是一直纸老虎,根本就不难。首先让我们搬出一个正在表达式在.net中的实现例子。

有这么一段json格式的文本,从右下图可以清除地看出其结构:

{ 
People: [ 
{ 
Name: "zhangsan", 
Age: 12, 
Married: false 
}, 
{ 
Name: "lisi", 
Age: 24, 
Married: true 
}, 
{ 
Name: "wangwu", 
Age: 40, 
Married: true 
} 
] 
}

正则表达式搭配js轻松处理json文本方便而老古

在c#中要想用正则提取出上述文本里面的有用信息,必须添加支持正则表达式的组件引用。
using System.Text.RegularExpressions;

static void Main(string[] args) 
{ 
string json = "{People:[{Name:\"zhangsan\",Age:12,Married:false},{Name:\"lisi\",Age:24,Married:true},{Name:\"wangwu\",Age:40,Married:true}]}"; 
Regex regex = new Regex(@"Name:\s*""(?'Name'[^""]*)"",\s*Age:\s*(?'Age'[^,]*),\s*Married:\s*(?'Married'[^\}]*)", RegexOptions.IgnoreCase); 
//申明和实例化一个正则表达式对象,这里要加上参数RegexOptions.IgnoreCase,用于忽略文本大小写 
if (regex.IsMatch(json)) 
{ 
MatchCollection matches = regex.Matches(json); 
//上处可以匹配文本里有多组相似的结果全部结果,如果只有一组的话,用Match match = regex.Match(json); 
StringBuilder stringBuilder = new StringBuilder(); 
foreach (Match match in matches) 
{ 
string name = match.Groups["Name"].Value;//此处Name是匹配表达式(?'Name'[^"]*)里的Name,显式分组 
string age = match.Groups["Age"].Value; 
string married = match.Groups["Married"].Value; 
stringBuilder.AppendFormat("Name:{0},Age:{1},Married:{2}\n", name,age,married); 
} 
Console.WriteLine(stringBuilder.ToString()); 
} 
else 
{ 
Console.WriteLine("提取文本失败!"); 
} 
Console.Read(); 
}

如果匹配正确,结果会是如图所示:

正则表达式搭配js轻松处理json文本方便而老古

很多新手都不知道这些步骤怎么来的。在这里我先向大家推荐一款正则表达式测试的小工具。由于是特别针对c#的,所以用起来真的很方便。至于下载地址百度一下就知道了!

 正则表达式搭配js轻松处理json文本方便而老古

这上面的匹配符让我介绍一下。

\s 匹配一个空格    * 匹配次数(这里是无限次,甚至是一次也没有){1,}是至少匹配一次或一次以上

\w匹配一个字母或是数字  \.这是匹配任何一个字符 

\d匹配一个数字,不包括前面的正负符号

()隐式分组   (?'groupname'\w)或者(?<groupname>\w)匹配一个字符的显式分组,包含了一个组名groupname,可以自己随便起名字。

[^\w]这里面的^是匹配除^后面出现的字符的所有字符。比如匹配 name:"haha123",要匹配这里面的haha123,就可以这样:name:"(?'name'[^"]*)表示匹配除"的所有字符haha123

其实正则表达式真正常用的也就是上面那几个了。会了的话正则表达式就轻松掌握了。

接下来还给大家介绍一种解析json的方法。那就是在.net调用javascript的脚本。

调用Javascript

这是一种被人忽略的方法,其实用这种方法解析起来貌似比上面的正则表达式更快速。

大家都知道,在json只是javascript里一种单独列出来的玩意,其语法遵循js,因此用js来原生态地处理json是最好不过了。

using Microsoft.JScript; 
using Microsoft.Vsa; 
using Microsoft.JScript.Vsa;

public static Dictionary<string, string> GetMyValue(string jsonSource, string key1, string key2) 
{ 
Dictionary<string, string> dic = new Dictionary<string, string>(); 
string jsonStr = "function handleJson() {var j=" + jsonSource + ";var arr1=new Array();var arr2=new Array();for(var " + key2 + " in j." + key1 + ") arr1.push(" + key2 + "); return arr1;} handleJson(); "; 
object o = Eval.JScriptEvaluate(jsonStr, VsaEngine.CreateEngine()); 
ArrayObject arr = (ArrayObject)o; 
for (var i = 0; i <= (int)arr.length - 1; i++) 
{ 
dic.Add(arr[i].ToString(), arr[i].ToString()); 
} 
return dic; 
}

这里的代码是我以前做项目的时候临时写的,很乱,大家将就着看看。只是作为一种可行的方法,并不推荐大家用这种方法。有时间大家试试看。

教程每天都更新,欢迎大家继续关注!

Javascript 相关文章推荐
input 和 textarea 输入框最大文字限制的jquery插件
Oct 27 Javascript
JavaScript实现动画打开半透明提示层的方法
Apr 21 Javascript
js获得当前系统日期时间的方法
May 06 Javascript
javascript文本模板用法实例
Jul 31 Javascript
前端性能优化及技巧
May 06 Javascript
十个免费的web前端开发工具详细整理
Sep 18 Javascript
vue微信分享 vue实现当前页面分享其他页面
Dec 02 Javascript
浅谈实现vue2.0响应式的基本思路
Feb 13 Javascript
代码分析vue中如何配置less
Sep 28 Javascript
AngularJS 多指令Scope问题的解决
Oct 25 Javascript
JS使用Prim算法和Kruskal算法实现最小生成树
Jan 17 Javascript
Node中对非阻塞I/O、事件循环的知识点总结
Jan 05 Javascript
jQuery图片播放8款精美插件分享
Feb 17 #Javascript
jQuery性能优化28条建议你值得借鉴
Feb 16 #Javascript
JavaScript调用堆栈及setTimeout使用方法深入剖析
Feb 16 #Javascript
js nextSibling属性和previousSibling属性概述及使用注意
Feb 16 #Javascript
jQuery事件绑定.on()简要概述及应用
Feb 07 #Javascript
10个基于浏览器的JavaScript调试工具分享
Feb 07 #Javascript
利用JQuery动画制作滑动菜单项效果实现步骤及代码
Feb 07 #Javascript
You might like
FirePHP 推荐一款PHP调试工具
2011/04/23 PHP
解析yahoo邮件用phpmailer发送的实例
2013/06/24 PHP
php缩小png图片不损失透明色的解决方法
2013/12/25 PHP
zf框架的db类select查询器join链表使用示例(zend框架)
2014/03/14 PHP
YII Framework框架教程之使用YIIC快速创建YII应用详解
2016/03/15 PHP
laravel框架添加数据,显示数据,返回成功值的方法
2019/10/11 PHP
jquery链式操作的正确使用方法
2014/01/06 Javascript
js实现简单的购物车有图有代码
2014/05/26 Javascript
JQuery简单实现锚点链接的平滑滚动
2015/05/03 Javascript
JS创建对象几种不同方法详解
2016/03/01 Javascript
javascript冒泡排序小结
2016/04/10 Javascript
AngularJS中实现用户访问的身份认证和表单验证功能
2016/04/21 Javascript
jQuery实现鼠标选中文字后弹出提示窗口效果【附demo源码】
2016/09/05 Javascript
AngularJS中的promise用法分析
2017/05/19 Javascript
JS实现鼠标拖拽盒子移动及右键点击盒子消失效果示例
2019/01/29 Javascript
jquery+php后台实现省市区联动功能示例
2019/05/23 jQuery
node实现爬虫的几种简易方式
2019/08/22 Javascript
vue 中的 render 函数作用详解
2020/02/28 Javascript
JavaScript实现指定数量的并发限制的示例代码
2020/03/10 Javascript
聊聊vue 中的v-on参数问题
2021/01/29 Vue.js
python3 requests中使用ip代理池随机生成ip的实例
2018/05/07 Python
Python整数与Numpy数据溢出问题解决
2019/09/11 Python
python3 googletrans超时报错问题及翻译工具优化方案 附源码
2020/12/23 Python
html5新增的属性和废除的属性简要概述
2013/02/20 HTML / CSS
村委会贫困证明
2014/01/14 职场文书
优秀学生干部推荐材料
2014/02/03 职场文书
模具专业毕业生自荐书范文
2014/02/19 职场文书
施工质量承诺书范文
2014/05/30 职场文书
本科生求职信
2014/06/17 职场文书
花坛标语大全
2014/06/30 职场文书
委托证明书
2014/09/17 职场文书
四风查摆问题自查报告
2014/10/10 职场文书
教师党员承诺书2015
2015/01/21 职场文书
税务会计岗位职责
2015/04/02 职场文书
如何起草一份正确的合伙创业协议书?
2019/07/04 职场文书
MySQL一劳永逸永久支持输入中文的方法实例
2022/08/05 MySQL