正则表达式搭配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 相关文章推荐
Javascript 函数对象的多重身份
Jun 28 Javascript
Highcharts 非常实用的Javascript统计图demo示例
Jul 03 Javascript
js校验表单后提交表单的三种方法总结
Feb 28 Javascript
基于jQuery插件实现点击小图显示大图效果
May 11 Javascript
js将table的每个td的内容自动赋值给其title属性的方法
Oct 13 Javascript
获取jqGrid中选择的行的数据
Nov 30 Javascript
vue.js从安装到搭建过程详解
Mar 17 Javascript
JS二叉树的简单实现方法示例
Apr 05 Javascript
vuejs点击class变化的实例
Sep 05 Javascript
17道题让你彻底理解JS中的类型转换
Aug 08 Javascript
JavaScript制作3D旋转相册
Aug 02 Javascript
微信小程序实现选项卡滑动切换
Oct 22 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
几行代码轻松实现PHP文件打包下载zip
2017/03/01 PHP
tagName的使用,留一笔
2006/06/26 Javascript
JQuery团队打造的javascript单元测试工具QUnit介绍
2010/02/26 Javascript
JQuery从头学起第一讲
2010/07/04 Javascript
初窥JQuery(二)事件机制(2)
2010/12/06 Javascript
使用Jquery搭建最佳用户体验的登录页面之记住密码自动登录功能(含后台代码)
2011/07/10 Javascript
jQuery contains过滤器实现精确匹配使用方法
2013/04/12 Javascript
JS实现闪动的title消息提醒效果
2014/06/20 Javascript
ie8模式下click无反应点击option无反应的解决方法
2014/10/11 Javascript
jQuery源码分析之Callbacks详解
2015/03/13 Javascript
jquery控制表单输入框显示默认值的方法
2015/05/22 Javascript
基于JS实现Android,iOS一个手势动画效果
2016/04/27 Javascript
vue.js或js实现中文A-Z排序的方法
2018/03/08 Javascript
vue中使用gojs/jointjs的示例代码
2018/08/24 Javascript
解决layui 三级联动下拉框更新时回显的问题
2019/09/03 Javascript
jQuery实现简单弹幕效果
2019/11/28 jQuery
详解Vue3 Composition API中的提取和重用逻辑
2020/04/29 Javascript
Python的Django框架中消息通知的计数器实现教程
2016/06/13 Python
python中的lambda表达式用法详解
2016/06/22 Python
Python外星人入侵游戏编程完整版
2020/03/30 Python
python利用正则表达式排除集合中字符的功能示例
2017/10/10 Python
Python实用库 PrettyTable 学习笔记
2019/08/06 Python
将Pytorch模型从CPU转换成GPU的实现方法
2019/08/19 Python
python根据时间获取周数代码实例
2019/09/30 Python
Django文件上传与下载(FileFlid)
2019/10/06 Python
mac系统下安装pycharm、永久激活、中文汉化详细教程
2020/11/24 Python
纯css3制作的火影忍者写轮眼开眼至轮回眼及进化过程实例
2014/11/11 HTML / CSS
浅谈Html5页面打开app的一些思考
2020/03/30 HTML / CSS
销售职业生涯规划范文
2014/03/14 职场文书
建筑安全生产责任书
2014/07/22 职场文书
委托书的写法
2014/08/30 职场文书
个人汇报材料范文
2014/12/30 职场文书
惊涛骇浪观后感
2015/06/05 职场文书
导游词之扬州大明寺
2019/10/09 职场文书
MySQL系列之六 用户与授权
2021/07/02 MySQL
Win11如何启用启动修复 ? Win11执行启动修复的三种方法
2022/04/08 数码科技