平时在作数据库插入操作时,如果用 INSERT 语句向一个varchar型字段插入内容时,有时会因为插入的内容长度超出规定的长度而报错。

尤其是插入中英文混合字符串时,SQL Server中一般中文要占两个字节,所以对混合型的字符串就要作一个处理,统一按字节长度来计算字符串长度,方法如下:

C#方法一:

public static string GetString(string str, int len)
{
string result = string.Empty;// 最终返回的结果
int byteLen = System.Text.Encoding.Default.GetByteCount(str);// 单字节字符长度
int charLen = str.Length;// 把字符平等对待时的字符串长度
int byteCount = ;// 记录读取进度
int pos = ;// 记录截取位置
if (byteLen > len)
{
for (int i = ; i < charLen; i++)
{
if (Convert.ToInt32(str.ToCharArray()[i]) > )// 按中文字符计算加2
byteCount += ;
else// 按英文字符计算加1
byteCount += ;
if (byteCount > len)// 超出时只记下上一个有效位置
{
pos = i;
break;
}
else if (byteCount == len)// 记下当前位置
{
pos = i + ;
break;
}
} if (pos >= )
result = str.Substring(, pos);
}
else
result = str; return result;
}

C#方法二:推荐

/// <summary>
/// 字符串截取函数
/// </summary>
/// <param name="inputStr">需要截取的字符串</param>
/// <param name="length">要截取的长度</param>
/// <returns></returns>
public static string SubString(string inputStr,int length)
{
if (string.IsNullOrEmpty(inputStr))
{
return "";
}
string temp = inputStr;
int j = , k = ; CharEnumerator ce = inputStr.GetEnumerator();
while (ce.MoveNext())
{
j += (ce.Current > && ce.Current < ) ? : ; if (j <= length)
{
k++;
}
else
{
temp = inputStr.Substring(, k);
break;
}
}
return temp;
}

JS方法一(推荐):

 function SubString(str, len, hasDot) {
///<summary>
////显示窗口
///</summary>
/// <param name="selector" type="String">
/// 1: str - 源字符串 /// 2: len - 要截取的长度。
/// 3: hasDot - 是否显示…。
/// </param>
var newLength = ;
var newStr = "";
var chineseRegex = /[^\x00-\xff]/g;
var singleChar = "";
var strLength = str.replace(chineseRegex, "**").length;
for (var i = ; i < strLength; i++) {
singleChar = str.charAt(i).toString();
if (singleChar.match(chineseRegex) != null) {
newLength += ;
}
else {
newLength++;
}
if (newLength > len) {
break;
}
newStr += singleChar;
} if (hasDot && strLength > len) {
newStr += "...";
}
return newStr;
}

JS方法二(由C#方法一改写成JS):

//****************************************************************
//* 名  称:获取指定字节长度的中英文混合字符串//* 功 能:平时在作数据库插入操作时,如果用 INSERT 语句向一个varchar型字段插入内容时,有时会因为插入的内容长度超出规定的长度而报错。
// 尤其是插入中英文混合字符串时,SQL Server中一般中文要占两个字节,所以对混合型的字符串就要作一个处理,统一按字节长度来计算字符串长度
// JS中的几个函数:
// charAt(num) //获取字符串的num位置的字符
// 字符转ascii码:用charCodeAt();
// ascii码转字符:用fromCharCode();
// 示例:
//<script>
//str="A";
//code = str.charCodeAt();
//str2 = String.fromCharCode(code);
//str3 = String.fromCharCode(0x60+26);
//document.write(code+'<br />');
//document.write(str2+'<br />');
//document.write(str3);
//</script>
//输出:
//65
//A
//z
//* 入口参数:str:需要计算的数据
//* 出口参数:返回str指定长度len的字符串(双字节(包含中文)长度为2,单字节长度为1)
//*****************************************************************
function JsSubString(str, len) {
var result = ""; // 最终返回的结果
var chineseRegex = /[^\x00-\xff]/g;
var byteLen = str.replace(chineseRegex, "**").length; // 单字节字符长度
var charLen = str.length; // 把字符平等对待时的字符串长度
var byteCount = ;// 记录读取进度
var pos = ;// 记录截取位置
if (byteLen > len)
{
for (var i = ; i < charLen; i++) {
if (str.split("")[i].charCodeAt() > )// 按中文字符计算加2
byteCount += ;
else// 按英文字符计算加1
byteCount += ;
if (byteCount > len)// 超出时只记下上一个有效位置
{
pos = i;
break;
}
else if (byteCount == len)// 记下当前位置
{
pos = i + ;
break;
}
} if (pos >= )
result = str.substring(, pos);
}
else
result = str; return result;
}

C#与JS实现 获取指定字节长度 中英文混合字符串 的方法的更多相关文章

  1. js截取指定字节长度的字符串

    默认的截取字符串都是根据字符长度或位置截取的,典型的两个方法是substr和substring. 这样导致的问题是截取同样长度的字符串时,多字节字符(汉字等)和单字节字符(半角英文字母.半角数字)占的 ...

  2. String截取字符串的指定字节长度

    /** TODO:截取字符串的指定字节长度 * @Author wenjing * @Date 11:02 2019/5/15 * @Param [str, bengin, end] * @retur ...

  3. js&jquery获取指定table指定行里面的内容

      js&jquery获取指定table指定行里面的内容 CreateTime--2018年5月18日11:46:04 Author:Marydon 1.展示 代码展示 <table s ...

  4. PHP获取中英文混合字符串长度及截取

    1.字符串长度 PHP获取中英文混合字符串长度的实现代码如下,1中文=1位,2英文=1位,可自行修改 /** * PHP获取字符串中英文混合长度 * @param $str string 字符串 *  ...

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

    很早以前写过一篇文章(用C#截取指定长度的中英文混合字符串),但是对性能没有测试,有人说我写的这个方法性能有问题,后来想,可能真会有BT之需求要求传入一个几万K甚至几M体积的字符串进来,那将会影响正则 ...

  6. PHP获取指定日期是星期几的实现方法

    这篇文章主要介绍了PHP获取指定日期是星期几的实现方法,涉及php针对日期的读取.判断与字符串.数组相关运算操作技巧,需要的朋友可以参考下 本文实例讲述了PHP获取指定日期是星期几的实现方法.分享给大 ...

  7. c#的中英文混合字符串截取指定长度,startidx从0开始

    //c#的中英文混合字符串截取指定长度,startidx从0开始 by gisoracle@126.com public string getStrLenB(string str, int start ...

  8. PyQt(Python+Qt)学习随笔:QTableWidget的获取指定位置项的item和itemAt方法

    老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 1.获取指定行和列的项 根据行和列可以获取对应位置的项,调用语法如下: QTableWidgetIt ...

  9. CSS截取中英文混合字符串长度

    <!doctype html> <html> <head> <meta http-equiv="content-type" content ...

随机推荐

  1. Java学习笔记 05 数据包装类

    一.包装类 综述 >>java.lang包中的Integer类.Long类和Short类,分别将基本数据类型int.long和short封装成一个类.这些类都是Number的子类. Int ...

  2. 响应式web设计之CSS3 Media Queries

    开始研究响应式web设计,CSS3 Media Queries是入门. Media Queries,其作用就是允许添加表达式用以确定媒体的环境情况,以此来应用不同的样式表.换句话说,其允许我们在不改变 ...

  3. easyui datagrid中关联combox

    datagrid中列上关联combobox{ field: 'SysCode', title: '系统代码', width: 150, align: 'left', editor: { type: ' ...

  4. 黑马程序员_Java基础:JDK1.5后的新特性:自动拆装箱,以及注意事项

    ------- android培训.java培训.期待与您交流! ---------- 首先来看一段代码: Integer x = new Integer(4); Integer y = 4; 在JD ...

  5. JQuery按回车提交数据

    引入JQuery文件 <script src="JS/jquery-1.9.1.js" type="text/javascript"></sc ...

  6. hdu 3065 AC自动机

    // hdu 3065 AC自动机 // // 题目大意: // // 给你n个短串,然后给你一个长串,问:各个短串在长串中,出现了多少次 // // 解题思路: // // AC自动机,插入,构建, ...

  7. Hbase随笔2

    Hbase是建立在HDFS上的分布式数据库,下图是Hbase表的模型: Hbase这个数据库其实和传统关系数据库还是有很多类似之处,而不是像mongodb,memcached以及redis完全脱离了表 ...

  8. nginx Windows服务形式运行

    背景 现在使用ngnix的人越来越多,nginx的优势劣势网上也很多说明.这里就不探讨nginx优势与劣势,每个工具都有自己优势劣势,没有最好的工具,只有最合适的工具.   如何选择适当的工具,根据项 ...

  9. android 编译代码注意事项

    1 安装openjdk1.7 sudo add-apt-repository ppa:openjdk-r/ppa sudo apt-apt update sudo apt-get install op ...

  10. android 开发禁止系统修改app的字体大小

    重写activity的getResources方法,一般在BaseActivity中重写就好了,其他activity继承BaseActivity //设置字体大小不随手机设置而改变 @Override ...