正则表达式获取URL参数

正则表达式获取URL参数 c#
 
ExpandedBlockStart.gif 代码
string  url = " ewfsefsefse?courseid=21312&fesf=213 " ;
Regex urlRegex 
=   new  Regex( @" (^|\?|&)courseid=\d*(&|$) " );
        Match m 
=  urlRegex.Match(url.ToLower());
        
string  courseId  = string .Empty;
        
if  (m.Success)
        {
            courseId 
=  m.Value;
        }

 

我获取的是 ?courseId=21312,我只想得到 21312 应该怎么写啊? 
问题补充:
url可能情况
1 ewfsefsefse?courseId=21312&fesf=213
2 ewfsefsefse?wefwe=1232&courseId=21312&fesf=213
3 ewfsefsefse?wefwe=1232&courseId=21312
 
   
Regex urlRegex  =   new  Regex( @" (?:^|\?|&)courseid=(\d*)(?:&|$) " );
........ 
courseId 
=  m.Groups[ 1 ].Value; 

 

我在CSDN上的提问(个人有一些理解错误)

(@"(^|\?|&)courseid=\d*(&|$)");

^符号在()分组中是非的作用吗?怎么感觉它是意思是起始是\?或&???

这个(^|\?|&)分组该怎么理解呢?

 

取了一些不错的回复:

一:

^ 只有出现在字符组[]的开始位置处,即[^char]这种语法时,才是“非”的意思

而在[]其它位置时,^表示的就是普通字符“^”,类似于“a”、“b”这样的普通字符

所以^在与其它子表达式表示“或”的关系时,只能用(exp1|exp2|exp3)这种语法

整个表达式的意思,就是从URL中取courseid=对应的value值
因为URL中的参数有两种情况,一种是跟在“?”后,另一种是跟在“&”后,而看你的例子,这里传进来的URL还可能全是参数,而不包含前面的文件,所以这里又加了一个“^”的条件

 

二:

表示字符串的开始匹配位置 $表示结束位置 | 表示或的关系 \表示转义符
?匹配前面的子表达式零次或一次。例如,"do(es)?" 可以匹配 "do" 或 "does" 中的"do" 。? 等价于 {0,1}。
(^|\?|&)可以理解为url?courseid或url?xx=xxxx&courseid 就是查询字符串courseid前是否还有其它键值对。

 

三:

(^|\?|&)courseid=\d*(&|$)
应该是:^字符串开头或者 \? 0或者1个\ &或者 & , 然后跟上 courseid= \d*任意个数字 (&|$) &或者$

 

四:

(^|\?|&)courseid=\d*(&|$)
表示字符串已 ? 或者 & 或者 courseid= 开始,courseid=后面一定要是数字,可以是多个数字,最后可以有&符号或者数字结尾,如一下几个都可以:
?courseid=111
&courseid=111
courseid=111
courseid=111&

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值