平时在作数据库插入操作时,如果用 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. mysql mHA manager 状态修改

    启动:nohup masterha_manager --conf=/etc/masterha/app1.cnf --remove_dead_master_conf --ignore_last_fail ...

  2. ILSpy搜索功能加强版

    1.修改搜索功能,增加如下的额外搜索选项 A.按文本搜索(默认选项) B.按通配符搜索 C.按正则表达式搜索 2.搜索增加如下特性: A.可以按照名字空间检索特定名字空间下的所有类. B.修正了官方版 ...

  3. nil、Nil、NULL和NSNull的理解

    http://blog.sina.com.cn/s/blog_4930f8e60101h71b.html 其实早就想研究一下nil.Nil.NULL和NSNull之间的区别,只是工作上除了nil,其它 ...

  4. Shiro权限验证代码记录,正确找到shiro框架在什么地方做了权限识别

    权限验证方式的验证代码: org.apache.shiro.web.servlet.AdviceFilter这个类是所有shiro框架提供的默认权限验证实例类的父类 验证代码: public void ...

  5. 骨骼动画的实现(OpenGL实现)

    人物模型动画一直是游戏中最重要的组成部分, 因此这里我们研究骨骼动画是如何实现的. 原理 首先模型通常是由多个三角形形成的网格构成, 每个三角形有三个顶点, 因此动画的根本原理就在于不同时间内为每个顶 ...

  6. 【Win10 UWP】后台任务与动态磁贴

    动态磁贴(Live Tile)是WP系统的大亮点之一,一直以来受到广大用户的喜爱.这一讲主要研究如何在UWP应用里通过后台任务添加和使用动态磁贴功能. 从WP7到Win8,再到Win10 UWP,磁贴 ...

  7. 【腾讯Bugly干货分享】移动互联网测试到质量的转变

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57ee0934b690d84c3188d7c7 Dev Club 是一个交流移动 ...

  8. mongodb( 实现join)

    mongodb提供ref和populate的方法,支持类似join的SQL操作.本文给出一个实际的例子: 1. 数据1: var daob = new Schema({ user: { type: S ...

  9. Request中的各种方法

    前言 Request中方法众多,对于Java Web程序员来说,种种方法都会在工作中常常用到.Request由于不是JDK的一部分,这些方法的用法也没有专门的API可以查,所以在工作中遇到Reques ...

  10. 作业二:在github上过程

    注册Github