zoukankan      html  css  js  c++  java
  • C#验证输入数据的字节数包括中文和英文

    public int GetBytesOfString(string str)
            {//获取字符串的字节数
                byte[] bytes = Encoding.Unicode.GetBytes(str);
                int n = 0;
                for (int i = 0; i < bytes.GetLength(0); i++)
                {
                    //  偶数位置,如0、2、4等,为UCS2编码中两个字节的第一个字节
                    if (i % 2 == 0)
                    {
                        n++;      //  在UCS2第一个字节时n加1
                    }
                    else
                    {
                        //  当UCS2编码的第二个字节大于0时,该UCS2字符为汉字,一个汉字算两个字节
                        if (bytes[i] > 0)
                        {
                            n++;
                        }
                    }
                }
                return n;
            }

           private string GetSubstringByLength(string str, ref int len)
            {//截取字符串指定字节数的内容,并返回实际截取的字节数
                byte[] bytes = Encoding.Unicode.GetBytes(str);
                int n = 0;  //  表示当前的字节数
                int i = 0;  //  要截取的字节数
                for (; i < bytes.GetLength(0) && n < len; i++)
                {
                    if (i % 2 == 0)//  偶数位置,如0、2、4等,为UCS2编码中两个字节的第一个字节
                    {
                        n++;      //  在UCS2第一个字节时n加1
                    }
                    else
                    {
                        if (bytes[i] > 0)//  当UCS2编码的第二个字节大于0时,该UCS2字符为汉字,一个汉字算两个字节
                        {
                            n++;
                        }
                    }
                }
                //  如果i为奇数时,处理成偶数
                if (i % 2 == 1)
                {
                    if (bytes[i] > 0) //  该UCS2字符是汉字时,去掉这个截一半的汉字
                        i = i - 1;
                    else
                        i = i + 1;//  该UCS2字符是字母或数字,则保留该字符
                }
                len = i;
                return Encoding.Unicode.GetString(bytes, 0, i);
            }

  • 相关阅读:
    XTREE随笔
    多重共线性
    常用特征选取算法
    最短路径算法的实现(dijskstra):Python
    数据科学的完整学习路径—Python版(转载)
    windows下64位python的安装及机器学习相关包的安装(实用)
    拓扑排序 详解 + 并查集 详解 + 最小生成树(MST)详解 【普利姆算法 + 优先队列优化 & 克鲁斯卡尔算法】
    最短路算法 :Bellman-ford算法 & Dijkstra算法 & floyd算法 & SPFA算法 详解
    在linux下部署项目所用到的基本linux命令
    素数筛 模板
  • 原文地址:https://www.cnblogs.com/wuhuisheng/p/1996389.html
Copyright © 2011-2022 走看看