截断字符串,取指定长度字符(中英文通用)

摘要:
Vs2008设计页:˂ahref='http://t.zoukankan.com/test.aspx?newsId='target=“_blank”˃˂/asp:

vs2008

设计页:

                                          <asp:TemplateField>
                                                <ItemTemplate>
                                                    <a href='http://t.zoukankan.com/test.aspx?newsId=<%#Eval("id") %>'target="_blank">
                                                     <%# CutString(Convert.ToString(Eval("content")), 30)%></a>
                                                </ItemTemplate>
                                            </asp:TemplateField>

代码页:

    /// <summary>
    /// 如果长度大于totalLen,则截取len长度,其余...添充
    /// </summary>
    /// <param name="s">要截取的字符串</param>
    /// <param name="len">截取的长度</param>
    /// <param name="totalLen">添充.后的总长度</param>
    /// <returns></returns>
    public string CutString(string s, int len)
    {
        int totalLen = 33;
        string result = ""; //最终返回的结果
        int byteLen = System.Text.Encoding.Default.GetByteCount(s);  //单字节字符长度
        if (byteLen <= totalLen) return s;
        int charLen = s.Length; //把字符平等对待时的字符串长度
        int byteCount = 0;  //记录读取进度{中文按两单位计算}
        int pos = 0;    //记录截取位置{中文按两单位计算}
        if (byteLen > len)
        {
            for (int i = 0; i < charLen; i++)
            {
                if (byteCount >= len)   //到达指定长度时,记录指针位置并停止
                {
                    pos = i;
                    break;
                }
                if (Convert.ToInt32(s.ToCharArray()[i]) > 255)  //遇中文字符计数加2
                    byteCount += 2;
                else         //按英文字符计算加1
                    byteCount += 1;

            }
            result = s.Substring(0, pos) + "".PadLeft(totalLen - byteCount, '.');
        }
        else
            result = s;

        return result;
    }

免责声明:文章转载自《截断字符串,取指定长度字符(中英文通用)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇mysql安装使用Spring MVC 相关资料整理下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

SQL Server:SQL Like 通配符特殊用法:Escape

 SQL Server:SQL Like 通配符特殊用法:Escape   %:匹配零个及多个任意字符; _:与任意单字符匹配; []:匹配一个范围; [^]:排除一个范围 Symbol Meaning like '5[%]' 5% like '[_]n' _n like '[a-cdf]' a, b, c, d, or f like...

JS编解码与Java编解码的对应关系

  最近前段在导出数据时会遇到“illegal character”的异常错误,结果发现是在请求地址中请求参数包含了空白字符(其编码为%C2%A0)或者是空格字符(其编码为%20),之前对空格字符情况是做了规避处理,而这次又出现了空白字符,要是后续还有其它特殊字符呢?那如何是好?难道每次遇到这些特使字符就在后端做特殊处理?这样显然不合适。既然后端对请求地址...

MySQL学习笔记:upper、lower、ucase、lacase——字符串函数

  在MySQL中,通过利用upper、lower、ucase、lacase几个函数对字符串进行大小写转换。 upper(str)——根据当前字符集映射返回字符串str,并将所有字符更改为大写。默认值是latin1(西欧cp1252)。 lower(str)——根据当前字符集映射返回字符串str,并将所有字符更改为小写。默认值是latin1(西欧cp12...

C#字符串(String)类型中@的用法

C# string 字符串的前面可以加 @(称作"逐字字符串")将转义字符()当作普通字符对待,比如: stringstr =@"C:Windows";等价于: stringstr ="C:\Windows";@ 字符串中可以任意换行,换行符及缩进空格都计算在字符串长度之内。 stringstr =@"<script type=""text/java...

多串匹配

meteor多串匹配 Description Input 第一行为一个整数n,表示文本的长度 第二行为一个长度为n的文本 第三行为一个整数m,表示模式串个数 下接m行,每行一个模式串  Output 共m行,若第i个模式串在文本中出现过则第i行输出YES,否则输出NO 数据范围 对于30%的数据,n<=10^3,m<=10^3; 对于80%的数...

【转】MFC 字体LOGFONT

Windows的字体LOGFONT   LOGFONT是Windows内部字体的逻辑结构,主要用于设置字体格式,其定义如下:typedef struct tagLOGFONTA{    LONG      lfHeight;    LONG      lfWidth;    LONG      lfEscapement;    LONG      lf...