C#获取一段HTML文本中的第一张图片和截取内容摘要代码
2016-10-17 12:16:00  By: dwtedx

有时候我们获得到的数据是一段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文本的一部分作为内容摘要、此时、我们可以运用下面这个方法

 #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.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


注意、方法中的bool StripHTML参数表示是否以HTMl文本方式输出、如果为True的话表示去除HTML标签与样式、截取到的是纯文本、反之就是以HTMl文本输出、这样我们就可以根据自己喜欢的方式来输出文本

若资源对你有帮助、浏览后有很大收获、不妨小额打赏我一下、你的鼓励是维持我不断写博客最大动力

想获取DD博客最新代码、你可以扫描下方的二维码、关注DD博客微信公众号(ddblogs)

或者你也可以关注我的新浪微博、了解DD博客的最新动态:DD博客官方微博(dwtedx的微博)

如对资源有任何疑问或觉得仍然有很大的改善空间、可以对该博文进行评论、希望不吝赐教

为保证及时回复、可以使用博客留言板给我留言: DD博客留言板(dwtedx的留言板)

感谢你的访问、祝你生活愉快、工作顺心、欢迎常来逛逛


快速评论


技术评论

  • 该技术还没有评论、赶快抢沙发吧...
DD记账
top
+