【发布时间】:2017-12-06 03:02:05
【问题描述】:
如何优化这段代码 sn-p?
string page = wc.DownloadString("https://www.youtube.com/browse_ajax?action_continuation=1&continuation=4qmFsgI8EhhVQ2ZXdHFQeUJNR183aTMzT2VlTnNaWncaIEVnWjJhV1JsYjNNZ0FEQUJPQUZnQVdvQWVnRTB1QUVB");
int pos;
while ((pos = page.IndexOf("/watch?v=")) > 0) {
page = page.Substring(pos);
page = page.Substring(page.IndexOf("video-time"));
page = page.Substring(page.IndexOf("aria-label"));
page = page.Substring(page.IndexOf(@"\u003e") + 6);
string vt = page.Substring(0, page.IndexOf(@"\u003c"));
page = page.Substring(page.IndexOf("title=") + 1);
page = page.Substring(page.IndexOf("title=") + 1);
page = page.Substring(page.IndexOf("title=") + 1);
page = page.Substring(page.IndexOf("\\\"") + 2);
string tt = page.Substring(0, page.IndexOf("\\\" aria-describedby="));
}
遗憾的是,我不能跳过一些 Substring 行,因为这似乎是找到正确出现 vt 和 tt 的唯一方法。
由于Substring 总是返回一个新字符串,我尝试了StringBuilder 的解决方案:
System.Text.StringBuilder sb=new System.Text.StringBuilder(wc.DownloadString("https://www.youtube.com/browse_ajax?action_continuation=1&continuation=4qmFsgI8EhhVQ2ZXdHFQeUJNR183aTMzT2VlTnNaWncaIEVnWjJhV1JsYjNNZ0FEQUJPQUZnQVdvQWVnRTB1QUVB"));
int pos;
while ((pos = sb.ToString().IndexOf("/watch?v=")) > 0) {
sb.Remove(0,pos);
sb.Remove(0,sb.ToString().IndexOf("video-time"));
sb.Remove(0,sb.ToString().IndexOf("aria-label"));
sb.Remove(0,sb.ToString().IndexOf(@"\u003e") + 6);
string vt =sb.ToString(0,sb.ToString().IndexOf(@"\u003c"));
sb.Remove(0,sb.ToString().IndexOf("title=") + 1);
sb.Remove(0,sb.ToString().IndexOf("title=") + 1);
sb.Remove(0,sb.ToString().IndexOf("title=") + 1);
sb.Remove(0,sb.ToString().IndexOf("\\\"") + 2);
string tt =sb.ToString(0,sb.ToString().IndexOf("\\\" aria-describedby="));
}
我惊讶地发现这个解决方案虽然看起来不像是因为ToString(),但确实稍微快了一点。
现在,有没有办法进一步优化它?也许甚至让它看起来更好?
【问题讨论】:
-
你可以跳过那些
SubStrings,IndexOf可以取一个起始位置,这样你就可以移动位置而不是复制大部分字符串。 -
但是我必须使用另一个 IndexOf 来定义起始位置,因为我不知道
vt和tt从哪里开始。这基本上重组了所有内容,使其成为一个不可读的单行,但我怀疑它是否会使其更高效或看起来更好 -
你当然不必把它写成单行。只需用
IndexOf更新一个位置,然后将其用作下一个IndexOf的起始位置,依此类推,直到达到目标 -
您可以使用来自this answer 的
StringBuilder的IndexOf()扩展方法,而不是进行所有这些ToString()调用。 -
... 或者这个:Fastest search method in StringBuilder.
标签: c# optimization substring stringbuilder indexof