正则表达式搭配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 相关文章推荐
简单的js分页脚本
May 21 Javascript
javascript将相对路径转绝对路径示例
Mar 14 Javascript
javascript中setTimeout的问题解决方法
May 08 Javascript
js+css绘制颜色动态变化的圈中圈效果
Jan 27 Javascript
JavaScript中的Reflect对象详解(ES6新特性)
Jul 22 Javascript
Vue.js仿Metronic高级表格(二)数据渲染
Apr 19 Javascript
老生常谈angularjs中的$state.go
Apr 24 Javascript
Vue+axios 实现http拦截及路由拦截实例
Apr 25 Javascript
基于Vue单文件组件详解
Sep 15 Javascript
shiro授权的实现原理
Sep 21 Javascript
WEEX环境搭建与入门详解
Oct 16 Javascript
微信小程序实现canvas分享朋友圈海报
Jun 21 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
thinkPHP删除前弹出确认框的简单实现方法
2016/05/16 PHP
jquery不支持toggle()高(新)版本的问题解决
2016/09/24 PHP
服务器安全设置的几个注册表设置
2007/07/28 Javascript
用js来解决ajax读取页面乱码
2010/11/28 Javascript
jQuery ReferenceError: $ is not defined 错误的处理办法
2013/05/10 Javascript
js给页面加style无效果的解决方法
2014/01/20 Javascript
JavaScript中检查对象property的存在性方法介绍
2014/12/30 Javascript
jQuery多条件筛选如何实现
2015/11/04 Javascript
jQuery的promise与deferred对象在异步回调中的作用
2016/05/03 Javascript
全面解析jQuery $(document).ready()和JavaScript onload事件
2016/06/08 Javascript
浅谈Angular.js中使用$watch监听模型变化
2017/01/10 Javascript
浅谈jQuery中事情的动态绑定
2017/02/12 Javascript
Angular 1.x个人使用的经验小结
2017/07/19 Javascript
详解在Vue中使用TypeScript的一些思考(实践)
2018/07/06 Javascript
springMvc 前端用json的方式向后台传递对象数组方法
2018/08/07 Javascript
layui 监听表格复选框选中值的方法
2018/08/15 Javascript
vue.js+ElementUI实现进度条提示密码强度效果
2020/01/18 Javascript
js实现双人五子棋小游戏
2020/05/28 Javascript
结合axios对项目中的api请求进行封装操作
2020/09/21 Javascript
JS如何操作DOM基于表格动态展示数据
2020/10/15 Javascript
[03:02]生活中的Dendi之野外度假篇
2016/08/09 DOTA
在Python中移动目录结构的方法
2016/01/31 Python
python实现连连看辅助(图像识别)
2020/03/25 Python
python如何实现数据的线性拟合
2019/07/19 Python
Python 一键获取百度网盘提取码的方法
2019/08/01 Python
Canvas高级路径操作之拖拽对象的实现
2019/08/05 HTML / CSS
优秀员工自荐信范文
2013/10/05 职场文书
中学生运动会入场词
2014/02/12 职场文书
教师党员岗位承诺书
2014/05/29 职场文书
小学校本培训方案
2014/06/06 职场文书
出生证明格式
2015/06/15 职场文书
2015最新婚礼司仪主持词
2015/06/30 职场文书
小学运动会通讯稿
2015/07/18 职场文书
开工典礼致辞
2015/07/29 职场文书
Python基础之变量的相关知识总结
2021/06/23 Python
mysqldump进行数据备份详解
2022/07/15 MySQL