分享

用C#截取指定长度的中英文混合字符串

 Icyhu 2008-03-20

用C#截取指定长度的中英文混合字符串

添加时间:2007-10-25 

我们常做的一件事情,就是在文章系统中,截取一定长度的文章标题,超过指定长度,就加“...”

如两个字符串:
string str1 = "中国人要啊abc呀~";
string str2 = "1中国人23456abc呀~";

要截取后,输出:

str1 = "中国人要...";
str2 = "1中国人2...";

即要把中英文混合的字符串,在截取后,长度要一致,即8个字节的长度(不包括三个点),而且不能出现中文被从中间截断的情况。于是写了个方法:

public static string getStr(string s,int l)
    {   
    string temp = s ;
    if (Regex.Replace(temp,"[\u4e00-\u9fa5]","zz",RegexOptions.IgnoreCase).Length<=l)
    {
        return temp;
    }
    for (int i=temp.Length;i>=0;i--)
    {
        temp = temp.Substring(0,i);
        if (Regex.Replace(temp,"[\u4e00-\u9fa5]","zz",RegexOptions.IgnoreCase).Length<=l-3)
        {
            return temp + "";
        }   
    }
    return "";
    }
调用:
string content = "中国人啊abc呀呀呀呀";
content = getStr(content,13);

 

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多