在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等多種語(yǔ)言都支持正則表達(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ù)庫(kù)、插入數(shù)據(jù)、從數(shù)據(jù)庫(kù)獲取時(shí)間示例
- C#從DataTable獲取數(shù)據(jù)的方法
- c# 獲取數(shù)據(jù)庫(kù)中所有表名稱的方法
- 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ù)庫(kù)名稱的方法
- 詳解如何獲取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-11
C# 中使用NModbus4通信庫(kù)執(zhí)行寫操作
在C#中NModbus4庫(kù)提供了一個(gè)方便的方式來與支持Modbus協(xié)議的設(shè)備進(jìn)行交互,本文就來介紹了使用NModbus4通信庫(kù)執(zhí)行寫操作,具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03
C#實(shí)現(xiàn)動(dòng)態(tài)加載dll的方法
這篇文章主要介紹了C#實(shí)現(xiàn)動(dòng)態(tài)加載dll的方法,涉及針對(duì)動(dòng)態(tài)鏈接庫(kù)的靈活操作技巧,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12
c#使用Socket發(fā)送HTTP/HTTPS請(qǐng)求的實(shí)現(xiàn)代碼
這篇文章主要介紹了c#使用Socket發(fā)送HTTP/HTTPS請(qǐng)求的實(shí)現(xiàn)代碼,需要的朋友可以參考下2017-09-09
asp.net中調(diào)用oracle存儲(chǔ)過程的方法
存儲(chǔ)過程是在大型數(shù)據(jù)庫(kù)系統(tǒng)中,一組為了完成特定功能的SQL 語(yǔ)句集,存儲(chǔ)在數(shù)據(jù)庫(kù)中經(jīng)過第一次編譯后再次調(diào)用不需要再次編譯,用戶通過指定存儲(chǔ)過程的名字并給出參數(shù)來執(zhí)行它,下面給大家介紹下asp.net中調(diào)用oracle存儲(chǔ)過程的方法,需要的朋友可以參考下2015-08-08

