您可以解决我使用String IndexOf方法时遇到的奇怪问题吗?
|
我有使用StreamReader从文件中读取HTML,然后调用ReadToEnd()函数的代码。 HTML存储为字符串。
然后,我将这一行代码称为:
string bookmarksBar = HTMLDoc.Substring(HTMLDoc.IndexOf(\">Bookmarks bar</H3>\"), HTMLDoc.IndexOf(\"</DL><p>\"));
因此,这里发生的是我想要HTML的特定部分,所以我使用的是字符串Substring方法。第一个参数是startIndex,第二个参数是长度。
我正在使用IndexOf方法,因此这一行代码将返回应在which1ѭ和\"</DL><p>\"
之间的一段文本
所以返回的字符串的末尾应该在找到\"</DL><p>\"
的地方,对吗?
然后的问题是,该字符串没有在找到“ 4”的地方结束,而是在此行之后结束了323个字符(我插入了四个星号来说明返回的字符串在哪里结束):
ICON=\"data:image/png;base64,iVBORw0KGgoAAA****ANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAABbklEQVQ4je3RPWuTYQCF4fs875uYKEilOA
我无法理解为什么它在这里结束,因为此时字符串不匹配\"</DL><p>\"
。
因此,这是HTML的较大部分:
jNpXrXKt4WFgn/KY1J1yBg874KWb0Vmr+BSttzgKt3LuBAAAAAElFTkSuQmCC\\\"></A>\\r\\n </DL><p>\\r\\n <DT><H3 ADD_DATE=\\\"1282073650\\\" LAST_MODIFIED=\\\"1301438557\\\">Link 1</H3>\\r\\n <DL><p>\\r\\n <DT><H3 ADD_DATE=\\\"1282073650\\\" LAST_MODIFIED=\\\"1286905747\\\">Link2</H3>\\r\\n <DL><p>\\r\\n <DT><A HREF=\\\"http://creators.xna.com/en-GB/create_detail#tour_four\\\" ADD_DATE=\\\"1282073650\\\" ICON=\\\"data:image/png;base64,iVBORw0KGgoAAA\"
您可以在上面的HTML中看到ѭ2,为什么它不止于此,而不是止于“ KGgoAAA”?
有任何想法吗?
谢谢
没有找到相关结果
已邀请:
4 个回复
缮记箔
第二个参数不是endIndex。 同样,按照这种方式,您最终会在结果中得到文本“ 1”。尝试这个:
耐扫鹤胶鞭
席陋临拈
郡豪靠暖