欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

C#教程

當前位置:主頁 > 軟件編程 > C#教程 >

C#獲取HTML文本的第一張圖片與截取內(nèi)容摘要示例代碼

來源:本站原創(chuàng)|時間:2020-01-10|欄目:C#教程|點擊: 次

獲取第一張圖片

要我們獲得到的數(shù)據(jù)是一段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文本

有時候我們得到的數(shù)據(jù)是一段HTML文本、需要截取HTML文本的一部分作為內(nèi)容摘要、此時、我們可以運用下面這個方法

示例代碼

 #region 新聞內(nèi)容摘要
/// <summary>
/// 新聞內(nèi)容摘要
/// </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.Replace(content, "");
    content = content.Replace(" ", "").Replace(" ", "");
    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

總結(jié)

以上就是利用C#獲取一段HTML文本中的第一張圖片和截取內(nèi)容摘要的全部內(nèi)容,希望本文的內(nèi)容對大家學習或者使用C#能有所幫助,如果有疑問大家可以留言交流,謝謝大家對我們的支持。

上一篇:C# 清除cookies的代碼

欄    目:C#教程

下一篇:談一談autofac組件的實例范圍

本文標題:C#獲取HTML文本的第一張圖片與截取內(nèi)容摘要示例代碼

本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/6205.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負任何責任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有