我有一个包含以下内容的HTML:
... some text ... link ... some text ... ... some text ... link ... some text ... ... some text ...
我想解析它并获得与命名组的匹配:
比赛1
组[ "用户"] = 123
组[ "部分"] = 2
比赛2
组[ "用户"] = 678
组[ "部分"] = 5
如果参数总是按顺序排列,我可以这样做,首先是User,然后是Section,但是如果顺序不同,我不知道怎么做.
谢谢!
在我的情况下,我不得不解析一个Url,因为WP7中没有实用程序HttpUtility.ParseQueryString.所以,我创建了一个像这样的扩展方法:
public static class UriExtensions { private static readonly Regex queryStringRegex; static UriExtensions() { queryStringRegex = new Regex(@"[\?&](?[^&=]+)=(? [^&=]+)"); } public static IEnumerable > ParseQueryString(this Uri uri) { if (uri == null) throw new ArgumentException("uri"); var matches = queryStringRegex.Matches(uri.OriginalString); for (int i = 0; i < matches.Count; i++) { var match = matches[i]; yield return new KeyValuePair (match.Groups["name"].Value, match.Groups["value"].Value); } } }
然后就是使用它的问题
var uri = new Uri(HttpUtility.UrlDecode(@"file.aspx?userId=123§ion=2"),UriKind.RelativeOrAbsolute); var parameters = uri.ParseQueryString().ToDictionary( kvp => kvp.Key, kvp => kvp.Value); var userId = parameters["userId"]; var section = parameters["section"];
注意:我正在返回IEnumerable而不是直接返回字典只是因为我假设可能存在重复参数的名称.如果存在重复的名称,则字典将引发异常.
为什么要使用正则表达式将其拆分出来?
您可以先解除查询字符串.将结果拆分为&,然后通过将结果与on =分开来创建地图