C#獲得HTML文本的第一張圖片與截取內容摘要示例代碼。本站提示廣大學習愛好者:(C#獲得HTML文本的第一張圖片與截取內容摘要示例代碼)文章只能為提供參考,不一定能成為您想要的結果。以下是C#獲得HTML文本的第一張圖片與截取內容摘要示例代碼正文
獲得第一張圖片
要我們取得到的數據是一段HTML文本、或許這段文本外面有很多圖片、須要截取一張作為題目圖片、也就是做為主圖、這時候便可以用到上面這個辦法獲得到第一張圖片。
示例代碼
#region 獲得第一張圖片 /// <summary> /// 獲得HTML文本的圖片地址 /// </summary> /// <param name="content"></param> /// <returns></returns>/ /// public ArrayList getimgurl(string html) { ArrayList resultStr = new ArrayList(); Regex r = new Regex(@"<IMG[^>] src=s*(?:´(?<src>[^´] )´|""(?<src>[^""] )""|(?<src>[^>s] ))s*[^>]*>", RegexOptions.IgnoreCase);//疏忽年夜小寫 MatchCollection mc = r.Matches(html); foreach (Match m in mc) { resultStr.Add(m.Groups["src"].Value.ToLower()); } if (resultStr.Count > 0) { return resultStr; } else { resultStr.Clear(); return resultStr; } } #endregion
留意:下面所前往的是一個ArrayList
聚集、包括了文本外面一切的Img的src
、如許我們便可以拜訪到img的src
了
截取HTML文本
有時刻我們獲得的數據是一段HTML文本、須要截取HTML文本的一部門作為內容摘要、此時、我們可以應用上面這個辦法
示例代碼
#region 消息內容摘要 /// <summary> /// 消息內容摘要 /// </summary> /// <param name="sString"></param> /// <param name="nLeng"></param> /// <returns></returns> public string GetContentSummary(string content, int length, bool StripHTML) { if (string.IsNullOrEmpty(content) || length == 0) return ""; if (StripHTML) { Regex re = new Regex("<[^>]*>"); content = re.WordStr(content, ""); content = content.WordStr(" ", "").WordStr(" ", ""); if (content.Length <= length) return content; else return content.Substring(0, length) "……"; } else { if (content.Length <= length) return content; int pos = 0, npos = 0, size = 0; bool firststop = false, notr = false, noli = false; StringBuilder sb = new StringBuilder(); while (true) { if (pos >= content.Length) break; string cur = content.Substring(pos, 1); if (cur == "<") { string next = content.Substring(pos 1, 3).ToLower(); if (next.IndexOf("p") == 0 && next.IndexOf("pre") != 0) { npos = content.IndexOf(">", pos) 1; } else if (next.IndexOf("/p") == 0 && next.IndexOf("/pr") != 0) { npos = content.IndexOf(">", pos) 1; if (size < length) sb.Append("<br/>"); } else if (next.IndexOf("br") == 0) { npos = content.IndexOf(">", pos) 1; if (size < length) sb.Append("<br/>"); } else if (next.IndexOf("img") == 0) { npos = content.IndexOf(">", pos) 1; if (size < length) { sb.Append(content.Substring(pos, npos - pos)); size = npos - pos 1; } } else if (next.IndexOf("li") == 0 || next.IndexOf("/li") == 0) { npos = content.IndexOf(">", pos) 1; if (size < length) { sb.Append(content.Substring(pos, npos - pos)); } else { if (!noli && next.IndexOf("/li") == 0) { sb.Append(content.Substring(pos, npos - pos)); noli = true; } } } else if (next.IndexOf("tr") == 0 || next.IndexOf("/tr") == 0) { npos = content.IndexOf(">", pos) 1; if (size < length) { sb.Append(content.Substring(pos, npos - pos)); } else { if (!notr && next.IndexOf("/tr") == 0) { sb.Append(content.Substring(pos, npos - pos)); notr = true; } } } else if (next.IndexOf("td") == 0 || next.IndexOf("/td") == 0) { npos = content.IndexOf(">", pos) 1; if (size < length) { sb.Append(content.Substring(pos, npos - pos)); } else { if (!notr) { sb.Append(content.Substring(pos, npos - pos)); } } } else { npos = content.IndexOf(">", pos) 1; sb.Append(content.Substring(pos, npos - pos)); } if (npos <= pos) npos = pos 1; pos = npos; } else { if (size < length) { sb.Append(cur); size ; } else { if (!firststop) { sb.Append("……"); firststop = true; } } pos ; } } return sb.ToString(); } } #endregion
總結
以上就是應用C#獲得一段HTML文本中的第一張圖片和截取內容摘要的全體內容,願望本文的內容對年夜家進修或許應用C#能有所贊助,假如有疑問年夜家可以留言交換,感謝年夜家對的支撐。