在C#中如何使用正式表達(dá)式獲取匹配所需數(shù)據(jù)
需求:獲取一串字符串中,正則匹配出需要的數(shù)據(jù)。
例如以下字符串:
string temp ="ErrorCode:-1,Message:{"UserId" : "1000","userName" : "ZhangSan"}";
我需要獲得“-1”和“{"UserId" : "1000","userName" : "ZhangSan"}”;
接下來(lái),就使用正則去匹配:
using System.Text.RegularExpressions;
string temp = "ErrorCode:-,Message:{\"UserId\" : \"\",\"userName\" : \"ZhangSan\"}";
Regex reg = new Regex("ErrorCode:(?<key>.*?),Message:{(?<key>.*?)}");
Match match = reg.Match(temp);
string tempStr = match.Groups["key"].Value + "--" + match.Groups["key"].Value;
MessageBox.Show(tempStr);

這時(shí)候tempStr得到的是”-1--{"UserId" : "1000","userName" : "ZhangSan"}“
下面給大家分享一段代碼有關(guān)C#中使用正則表達(dá)式自動(dòng)匹配并獲取所需要的數(shù)據(jù)
正則表達(dá)式能根據(jù)設(shè)置匹配各種數(shù)據(jù)(比如:e-mail地址,電話號(hào)碼,身份中號(hào)碼等等)。正則表達(dá)式功能強(qiáng)大,使用靈活,C#,Java,JavaScript等多種語(yǔ)言都支持正則表達(dá)式。在互聯(lián)網(wǎng)上“抓取數(shù)據(jù)”更是少不了使用正則表達(dá)式。今天我要說(shuō)的是在C#中使用正則表達(dá)式自動(dòng)匹配并獲取所需要的數(shù)據(jù)。
從下面是某個(gè)IP查詢網(wǎng)站返回查詢結(jié)果的一個(gè)部分(字符串),現(xiàn)在就是要從這個(gè)字符串中獲取“查詢結(jié)果1:”后面的“北京市 網(wǎng)通”。
< td align ="center" >< ul >< li > 查詢結(jié)果1:北京市 網(wǎng)通 </ li >< li > 查詢結(jié)果2:北京市 網(wǎng)通 </ li >< li > 查詢結(jié)果3:北京市 網(wǎng)通 </ li ></ ul ></ td >
C#相關(guān)代碼如下:
string srcString = " <td align=\ " center\ " ><ul><li>查詢結(jié)果1:北京市 網(wǎng)通</li><li>查詢結(jié)果2:北京市 網(wǎng)通</li><li>查詢結(jié)果3:北京市 網(wǎng)通</li></ul></td> " ; // 匹配 "<li>查詢結(jié)果1:" 與 "</li>" 之間的所有字符的正則表達(dá)式 string regexStr = " <li>查詢結(jié)果1:(?<key>.*?)</li> " ; Regex r = new Regex(regexStr, RegexOptions.None); Match mc = r.Match(srcString); string dataStr = mc.Groups[ " key " ].Value;
說(shuō)明:
這里最關(guān)鍵的是設(shè)置正則表達(dá)式: " <li>查詢結(jié)果1:(?<key>.*?)</li> "。
|
字符 |
描述 |
|
<key> |
根據(jù)key獲取由正則表達(dá)式匹配的值。 |
|
. |
匹配除 "\n" 之外的任何單個(gè)字符。 |
|
* |
匹配前面的子表達(dá)式零次或多次。 |
|
? |
跟在任何一個(gè)其他限制符(*, +, ?, {n}, {n,}, {n,m})后面時(shí),匹配模式是非貪婪的;非貪婪模式盡可能少的匹配所搜索的字符串,而默認(rèn)的貪婪模式則盡可能多的匹配所搜索的字符串。 |
dataStr 就是我們要得的數(shù)據(jù):“北京市 網(wǎng)通”。
- c#連接sqlserver數(shù)據(jù)庫(kù)、插入數(shù)據(jù)、從數(shù)據(jù)庫(kù)獲取時(shí)間示例
- C#從DataTable獲取數(shù)據(jù)的方法
- c# 獲取數(shù)據(jù)庫(kù)中所有表名稱的方法
- C#操作DataTable方法實(shí)現(xiàn)過(guò)濾、取前N條數(shù)據(jù)及獲取指定列數(shù)據(jù)列表的方法
- C#使用SqlDataAdapter對(duì)象獲取數(shù)據(jù)的方法
- C#實(shí)現(xiàn)解析百度天氣數(shù)據(jù),Rss解析百度新聞以及根據(jù)IP獲取所在城市的方法
- C#獲取所有SQL Server數(shù)據(jù)庫(kù)名稱的方法
- 詳解如何獲取C#類中發(fā)生數(shù)據(jù)變化的屬性信息
- C#中獲取數(shù)據(jù)的方法實(shí)例
相關(guān)文章
C# XML與Json之間相互轉(zhuǎn)換實(shí)例詳解
這篇文章主要介紹了C# XML與Json之間相互轉(zhuǎn)換實(shí)例詳解,大家參考使用吧2013-11-11
C#中使用DevExpress中的ChartControl實(shí)現(xiàn)極坐標(biāo)圖的案例詳解
這篇文章主要介紹了在C#中使用DevExpress中的ChartControl實(shí)現(xiàn)極坐標(biāo)圖,本案例是使用的是DevExpress 18.1.3版本,之前在14版本上也試過(guò),但是有一個(gè)弊端就是實(shí)現(xiàn)極坐標(biāo)圖的時(shí)候,第一個(gè)點(diǎn)和最后一個(gè)點(diǎn)總是自動(dòng)多一條閉合線,會(huì)形成一個(gè)閉合的多邊形,因此升級(jí)了一下版2022-02-02
C#實(shí)現(xiàn)不同窗體之間傳遞參數(shù)
這篇文章主要介紹了C#實(shí)現(xiàn)不同窗體之間傳遞參數(shù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
基于Silverlight DataGrid中無(wú)代碼設(shè)置開(kāi)始與結(jié)束日期DatePicker的實(shí)現(xiàn)方法
本篇文章是對(duì)Silverlight DataGrid中無(wú)代碼設(shè)置開(kāi)始與結(jié)束日期DatePicker的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
C# out關(guān)鍵詞的應(yīng)用實(shí)例
下面小編就為大家分享一篇C# out關(guān)鍵詞的應(yīng)用實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
C#中通過(guò)LRU實(shí)現(xiàn)通用高效的超時(shí)連接探測(cè)
這篇文章主要介紹了c#中通過(guò)LRU實(shí)現(xiàn)通用高效的超時(shí)連接探測(cè),非常不錯(cuò),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2018-11-11

