正则表达式搭配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+CSS实现弹出居中背景半透明div层的方法
Feb 26 Javascript
jQuery实现仿腾讯微博滑出效果报告每日天气的方法
May 11 Javascript
Spring mvc 接收json对象
Dec 10 Javascript
vue中配置mint-ui报css错误问题的解决方法
Oct 11 Javascript
Vue按需加载的具体实现
Dec 02 Javascript
Vue结合Video.js播放m3u8视频流的方法示例
May 04 Javascript
vue3.0 CLI - 2.3 - 组件 home.vue 中学习指令和绑定
Sep 14 Javascript
使用wxapp-img-loader自定义组件实现微信小程序图片预加载功能
Oct 18 Javascript
实例讲解JavaScript截取字符串
Nov 30 Javascript
vue 实现cli3.0中使用proxy进行代理转发
Oct 30 Javascript
浅谈vuex中store的命名空间
Nov 08 Javascript
JavaScript展开运算符和剩余运算符的区别详解
Feb 18 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 syntax error, unexpected $end 错误的一种原因及解决
2008/10/25 PHP
PHP 删除文件与文件夹操作 unlink()与rmdir()这两个函数的使用
2011/07/17 PHP
PHP最常用的2种设计模式工厂模式和单例模式介绍
2012/08/14 PHP
thinkphp中U方法按路由规则生成url的方法
2018/03/12 PHP
php文件上传原理与实现方法详解
2019/12/20 PHP
javascript 写类方式之四
2009/07/05 Javascript
ExtJS Window 最小化的一种方法
2009/11/18 Javascript
JavaScript 盒模型 尺寸深入理解
2012/12/31 Javascript
javascript实现数独解法
2015/03/14 Javascript
jquery的父、子、兄弟节点查找,节点的子节点循环方法
2016/12/07 Javascript
Vue.js仿Metronic高级表格(一)静态设计
2017/04/17 Javascript
详解webpack进阶之loader篇
2017/08/23 Javascript
Vue Element使用icon图标教程详解(第三方)
2018/02/07 Javascript
vue 2.x 中axios 封装的get 和post方法
2018/02/28 Javascript
Auto.js自动收取自己和好友蚂蚁森林能量脚本
2018/06/28 Javascript
JavaScript实现消消乐的源代码
2021/01/12 Javascript
[00:12]DAC SOLO赛卫冕冠军 VG.Paparazi灬展现SOLO技巧
2018/04/06 DOTA
python实现查找excel里某一列重复数据并且剔除后打印的方法
2015/05/26 Python
python爬虫框架talonspider简单介绍
2017/06/09 Python
Python中生成器和迭代器的区别详解
2018/02/10 Python
dataframe设置两个条件取值的实例
2018/04/12 Python
tensorflow使用神经网络实现mnist分类
2018/09/08 Python
Flask之请求钩子的实现
2018/12/23 Python
浅谈Python批处理文件夹中的txt文件
2019/03/11 Python
python二维码操作:对QRCode和MyQR入门详解
2019/06/24 Python
python中p-value的实现方式
2019/12/16 Python
flask利用flask-wtf验证上传的文件的方法
2020/01/17 Python
中专毕业生的自我鉴定
2013/12/01 职场文书
八年级英语教学反思
2014/01/09 职场文书
决定成败的关键——创业计划书
2014/01/24 职场文书
服务员岗位职责
2014/01/29 职场文书
大二法学专业职业生涯规划范文
2014/02/12 职场文书
网络技术专业推荐信
2014/02/20 职场文书
教师四风对照检查材料思想汇报
2014/09/17 职场文书
教师工作决心书
2015/02/04 职场文书
html2 canvas svg不能识别的解决方案
2021/06/03 HTML / CSS