在C#中如何使用正式表達(dá)式獲取匹配所需數(shù)據(jù)
需求:獲取一串字符串中,正則匹配出需要的數(shù)據(jù)。
例如以下字符串:
string temp ="ErrorCode:-1,Message:{"UserId" : "1000","userName" : "ZhangSan"}";
我需要獲得“-1”和“{"UserId" : "1000","userName" : "ZhangSan"}”;
接下來,就使用正則去匹配:
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等多種語言都支持正則表達(dá)式。在互聯(lián)網(wǎng)上“抓取數(shù)據(jù)”更是少不了使用正則表達(dá)式。今天我要說的是在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;
說明:
這里最關(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ù)庫、插入數(shù)據(jù)、從數(shù)據(jù)庫獲取時(shí)間示例
- C#從DataTable獲取數(shù)據(jù)的方法
- c# 獲取數(shù)據(jù)庫中所有表名稱的方法
- C#操作DataTable方法實(shí)現(xiàn)過濾、取前N條數(shù)據(jù)及獲取指定列數(shù)據(jù)列表的方法
- C#使用SqlDataAdapter對(duì)象獲取數(shù)據(jù)的方法
- C#實(shí)現(xiàn)解析百度天氣數(shù)據(jù),Rss解析百度新聞以及根據(jù)IP獲取所在城市的方法
- C#獲取所有SQL Server數(shù)據(jù)庫名稱的方法
- 詳解如何獲取C#類中發(fā)生數(shù)據(jù)變化的屬性信息
- C#中獲取數(shù)據(jù)的方法實(shí)例
相關(guān)文章
C#實(shí)現(xiàn)的xml操作類完整實(shí)例
這篇文章主要介紹了C#實(shí)現(xiàn)的xml操作類,包含C#針對(duì)xml的創(chuàng)建、刪除、遍歷、插入等常見操作,需要的朋友可以參考下2016-06-06關(guān)于C#中yield關(guān)鍵字的深入解析
這篇文章主要給大家介紹了關(guān)于C#中yield關(guān)鍵字的深入解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者使用C#具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11C#實(shí)現(xiàn)動(dòng)態(tài)加載dll的方法
這篇文章主要介紹了C#實(shí)現(xiàn)動(dòng)態(tài)加載dll的方法,涉及針對(duì)動(dòng)態(tài)鏈接庫的靈活操作技巧,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12c#使用Socket發(fā)送HTTP/HTTPS請(qǐng)求的實(shí)現(xiàn)代碼
這篇文章主要介紹了c#使用Socket發(fā)送HTTP/HTTPS請(qǐng)求的實(shí)現(xiàn)代碼,需要的朋友可以參考下2017-09-09asp.net中調(diào)用oracle存儲(chǔ)過程的方法
存儲(chǔ)過程是在大型數(shù)據(jù)庫系統(tǒng)中,一組為了完成特定功能的SQL 語句集,存儲(chǔ)在數(shù)據(jù)庫中經(jīng)過第一次編譯后再次調(diào)用不需要再次編譯,用戶通過指定存儲(chǔ)過程的名字并給出參數(shù)來執(zhí)行它,下面給大家介紹下asp.net中調(diào)用oracle存儲(chǔ)過程的方法,需要的朋友可以參考下2015-08-08