平时在作数据库插入操作时,如果用 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. 访问控制public/protected/private的区别

    Java支持四种不同的访问权限: 修饰符 说明 public 共有的,对所有类可见. protected 受保护的,对同一包内的类和所有子类可见. private 私有的,在同一类内可见. 默认的 在 ...

  2. CSS伪类选择器

    一.CSS伪类选择器用于给某些选择器添加效果语法规则:选择器:伪选择器例:a:link {color: #FF0000} 未访问的链接 a:visited {color: #00FF00} 已访问的链 ...

  3. opencv在ios上的开发教程

    http://docs.opencv.org/doc/tutorials/ios/hello/hello.html  openCV 2.4.3 iOS background_segm.hpp 'lis ...

  4. TSP旅行商问题的Hopfield求解过程

      连续型Hopfield在matlab中没有直接的工具箱,所以我们们根据Hopfield给出的连续行算法自行编写程序.本文中,以求解旅行商 问题来建立Hopfield网络,并得到解,但是该解不一定是 ...

  5. java.util.zip.ZipException: invalid entry size 解决办法

    启动maven项目时报java.util.zip.ZipException: invalid entry size (expected 7612 but got 5955 bytes) 可能是mave ...

  6. Android技术点

    一.四大组件 1.1  Activity 1.2  Broadcast 1.3  Content Provider 1.4  Service 1. Binder 2. Messager 3. AIDL ...

  7. 对json排序

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. sharepoint学习。

    企业门户:对全公司共用的信息进行统一管理.存储和发布,确保信息在公司范围内能够被及时传递 报表中心:集中管理.授权并发布所有业务报表,为各级管理人员提供各种数据.图形分析报表 办公协作:提供用户日常工 ...

  9. jquery datepicker 只显示年月

    首先修改默认日期赋值 <script type="text/javascript"> $(function(){ $('#searchDate').datepicker ...

  10. [转]Oracle VM VirtualBox虚拟机,Ubuntu虚拟机共享文件夹

    VirtualBox的菜单里选择"设备" -> "安装增强功能...". "设备" -> "共享文档夹",添 ...