下面是小编为大家收集的按字节截取字符串,本文共7篇,仅供参考,欢迎大家阅读,一起分享。

篇1:按字节截取字符串
按字节截取字符串
1.日本网站上使用的一种方法
select substring(CAST(カラム as TEXT),n,m)
2.个人经常使用的方法
select Cast('中文z哈hongwen123' As varchar(7)) as ee
3.和cast相同的一种
select convert(varchar(200), substring(convert(varbinary(200),'中文z高wen123'), 1, 6))
篇2:Go语言按字节截取字符串的方法
作者:不吃皮蛋 字体:[增加 减小] 类型:
这篇文章主要介绍了Go语言按字节截取字符串的方法,涉及Go语言操作字符串的技巧,非常具有实用价值,需要的朋友可以参考下
本文实例讲述了Go语言按字节截取字符串的方法,分享给大家供大家参考。具体实现方法如下:
代码如下:
// 按字节截取字符串 utf-8不乱码
func SubstrByByte(str string, length int) string {
bs := []byte(str)[:length]
bl := 0
for i:=len(bs)-1; i>=0; i-- {
switch {
case bs[i] >= 0 && bs[i] <= 127:
return string(bs[:i+1])
case bs[i] >= 128 && bs[i] <= 191:
bl++;
case bs[i] >= 192 && bs[i] <= 253:
cl := 0
switch {
case bs[i] & 252 == 252:
cl = 6
case bs[i] & 248 == 248:
cl = 5
case bs[i] & 240 == 240:
cl = 4
case bs[i] & 224 == 224:
cl = 3
default:
cl = 2
}
if bl+1 == cl {
return string(bs[:i+cl])
}
return string(bs[:i])
}
}
return “”
}
希望本文所述对大家的Go语言程序设计有所帮助,
篇3:go语言按显示长度截取字符串的方法
作者:不吃皮蛋 字体:[增加 减小] 类型:转载
根据显示长度截取字符串,之前php用的utf8编码,10个英文和10个汉字的显示长度差距太大,按字节截取的话又会出错出现截取半个汉字的情况,所以写了这两个函数.
这两天在折腾golang,所以就用golang重写了着连个函数.代码如下:
代码如下:
package main
import (
“fmt”
)
func main {
fmt.Println(show_strlen(“哈哈1”))
fmt.Println(show_substr(“哈哈1什1么的”, 9))
}
根绝显示长度截取字符串
代码如下:
func show_substr(s string, l int) string {
if len(s) <= l {
return s
}
ss, sl, rl, rs := “”, 0, 0, []rune(s)
for _, r := range rs {
rint := int(r)
if rint < 128 {
rl = 1
} else {
rl = 2
}
if sl + rl >l {
break
}
sl += rl
ss += string(r)
}
return ss
}
根据字符串显示获取显示长度
代码如下:
func show_strlen(s string) int {
sl := 0
rs := []rune(s)
for _, r := range rs {
rint := int(r)
if rint < 128 {
sl++
} else {
sl += 2
}
}
return sl
}
希望本文所述对大家的Go语言程序设计有所帮助,
篇4:asp实现截取字符串函数
这篇文章主要介绍了asp实现截取字符串函数,代码非常简洁,也非常实用,这里分享给大家,有需要的小伙伴参考下吧,
如果标题过长,因为页面布局的限制,只能列表10个字符,这个函数会帮你实现的
代码如下:
‘截取字符串 strvalue(标题,字数)
function strvalue(str,lennum)
dim p_num
dim i
if strlen(str)<=lennum then
strvalue=str
else
p_num=0
x=0
do while not p_num >lennum-2
x=x+1
if asc(mid(str,x,1))<0 then
p_num=int(p_num) + 2
else
p_num=int(p_num) + 1
end if
strvalue=left(trim(str),x)&“…”
loop
end if
end function
function strlen(str)
dim page_len
page_len=0
strlen=0
if trim(str)“” then
page_len=len(trim(str))
for xx=1 to page_len
if asc(mid(str,xx,1))<0 then
strlen=int(strlen) + 2
else
strlen=int(strlen) + 1
end if
next
end if
end function
使用方法:
代码如下:
<%=strvalue(“准确的编程语言,可正确对代码语法着色,输入简单几个字的代码片段说明”,10)%>
以上所述就是本文的全部内容了,希望大家能够喜欢,
篇5:linux字节截取命令之cut
执行权限:所有用户
所在位置:/usr/bin/cut
语 法:cut options... file...
功 能:字符截取命令,以TAB(制表符)为默认分隔符
局 限:空格作为分隔符时,则cut命令不能提取
选 项:
-f 列
cut -f 2 test.txt提取第二列(以制表符为默认分隔符)
cut -f 2-5,8 test.txt 提取第2、3、4、5、8列(以制表符为默认分隔符)
-d 指定分隔符
cut -d “,” -f 2,3 test.txt 以逗号为分隔符,提取第2和3列
篇6:PHP截取中文字符串方法总结
程序一:PHP截取中文字符串方法
由于网站首页以及vTigerCRM里经常在截取中文字符串时出现乱码(使用substr),今天找到一个比较好的截取中文字符串方法,在此与大家共享,
function msubstr($str, $start, $len) {
$tmpstr = “”;
$strlen = $start + $len;
for($i = 0; $i < $strlen; $i++) {
if(ord(substr($str, $i, 1)) >0xa0) {
$tmpstr .= substr($str, $i, 2);
$i++;
} else
$tmpstr .= substr($str, $i, 1);
}
return $tmpstr;
}
程序二:PHP截取UTF-8字符串,解决半字符问题
/******************************************************************
* PHP截取UTF-8字符串,解决半字符问题。
* 英文、数字(半角)为1字节(8位),中文(全角)为3字节
* @return 取出的字符串, 当$len小于等于0时, 会返回整个字符串
* @param $str 源字符串
* $len 左边的子串的长度
****************************************************************/
function utf_substr($str,$len)
{
for($i=0;$i<$len;$i++)
{
$temp_str=substr($str,0,1);
if(ord($temp_str) >127)
{
$i++;
if($i<$len)
{
$new_str[]=substr($str,0,3);
$str=substr($str,3);
}
}
else
{
$new_str[]=substr($str,0,1);
$str=substr($str,1);
}
}
return join($new_str);
}
?>
php utf-8 字符串截取
function cutstr($string, $length) {
preg_match_all(“/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|\xe0[\xa0-\xbf][\x80-\xbf]|[\xe1-\xef][\x80-\xbf][\x80-\xbf]|\xf0[\x90-\xbf][\x80-\xbf][\x80-\xbf]|[\xf1-\xf7][\x80-\xbf][\x80-\xbf][\x80-\xbf]/”, $string, $info);
for($i=0; $i
$wordscut .= $info[0][$i];
$j = ord($info[0][$i]) >127 ? $j + 2 : $j + 1;
if ($j >$length - 3) {
return $wordscut.“ ...”;
}
}
return join('', $info[0]);
}
$string=“242432反对感是456犯得上广泛大使馆地方7890”;
for($i=0;$i
{
echo cutstr($string,$i).“
”;
}
?>
截取utf-8字符串函数
为了支持多语言,数据库里的字符串可能保存为UTF-8编码,在网站开发中可能需要用php截取字符串的一部分。为了避免出现乱码现象,编写如下的UTF-8字符串截取函数
关于utf-8的原理请看 UTF-8 FAQ
UTF-8编码的字符可能由1~3个字节组成, 具体数目可以由第一个字节判断出来,
(理论上可能更长,但这里假设不超过3个字节)
第一个字节大于224的,它与它之后的2个字节一起组成一个UTF-8字符
第一个字节大于192小于224的,它与它之后的1个字节组成一个UTF-8字符
否则第一个字节本身就是一个英文字符(包括数字和一小部分标点符号)。
以前为某网站设计的代码(也是现在用在首页的长度截取的函数)
//$sourcestr 是要处理的字符串
//$cutlength 为截取的长度(即字数)
function cut_str($sourcestr,$cutlength)
{
$returnstr='';
$i=0;
$n=0;
$str_length=strlen($sourcestr);//字符串的字节数
while (($n<$cutlength) and ($i<=$str_length))
{
$temp_str=substr($sourcestr,$i,1);
$ascnum=Ord($temp_str);//得到字符串中第$i位字符的ascii码
if ($ascnum>=224) //如果ASCII位高与224,
{
$returnstr=$returnstr.substr($sourcestr,$i,3); //根据UTF-8编码规范,将3个连续的字符计为单个字符
$i=$i+3; //实际Byte计为3
$n++; //字串长度计1
}
elseif ($ascnum>=192) //如果ASCII位高与192,
{
$returnstr=$returnstr.substr($sourcestr,$i,2); //根据UTF-8编码规范,将2个连续的字符计为单个字符
$i=$i+2; //实际Byte计为2
$n++; //字串长度计1
}
elseif ($ascnum>=65 && $ascnum<=90) //如果是大写字母,
{
$returnstr=$returnstr.substr($sourcestr,$i,1);
$i=$i+1; //实际的Byte数仍计1个
$n++; //但考虑整体美观,大写字母计成一个高位字符
}
else //其他情况下,包括小写字母和半角标点符号,
{
$returnstr=$returnstr.substr($sourcestr,$i,1);
$i=$i+1; //实际的Byte数计1个
$n=$n+0.5; //小写字母和半角标点等与半个高位字符宽...
}
}
if ($str_length>$cutlength){
$returnstr = $returnstr . “...”;//超过长度时在尾处加上省略号
}
return $returnstr;
}
截取utf-8字符串函数
function FSubstr($title,$start,$len=“”,$magic=true)
{
if($len == “”) $len=strlen($title);
if($start != 0)
{
$startv = ord(substr($title,$start,1));
if($startv >= 128)
{
if($startv < 192)
{
for($i=$start-1;$i>0;$i--)
{
$tempv = ord(substr($title,$i,1));
if($tempv >= 192) break;
}
$start = $i;
}
}
}
if(strlen($title)<=$len) return substr($title,$start,$len);
篇7:Lua获取utf8字符串长度和字符串截取并用...代替
这篇文章主要介绍了Lua获取utf8字符串长度和字符串截取并用...代替,本文直接给出两个函数的实现代码,需要的朋友可以参考下
一、LUA获取utf8字符串长度
代码如下:
--- 获取utf8编码字符串正确长度的方法
-- @param str
-- @return number
function utfstrlen(str)
local len = #str;
local left = len;
local cnt = 0;
local arr={0,0xc0,0xe0,0xf0,0xf8,0xfc};
while left ~= 0 do
local tmp=string.byte(str,-left);
local i=#arr;
while arr[i] do
if tmp>=arr[i] then left=left-i;break;end
i=i-1;
end
cnt=cnt+1;
end
return cnt;
end
二、截取给定字符串的部分长度,超出部分用省略号“.”替换
代码如下:
--@brief 切割字符串,并用“...”替换尾部
--@param sName:要切割的字符串
--@return nMaxCount,字符串上限,中文字为2的倍数
--@param nShowCount:显示英文字个数,中文字为2的倍数,可为空
--@note 函数实现:截取字符串一部分,剩余用“...”替换
function GetShortName(sName,nMaxCount,nShowCount)
if sName == nil or nMaxCount == nil then
return
end
local sStr = sName
local tCode = {}
local tName = {}
local nLenInByte = #sStr
local nWidth = 0
if nShowCount == nil then
nShowCount = nMaxCount - 3
end
for i=1,nLenInByte do
local curByte = string.byte(sStr, i)
local byteCount = 0;
if curByte>0 and curByte<=127 then
byteCount = 1
elseif curByte>=192 and curByte<223 then
byteCount = 2
elseif curByte>=224 and curByte<239 then
byteCount = 3
elseif curByte>=240 and curByte<=247 then
byteCount = 4
end
local char = nil
if byteCount >0 then
char = string.sub(sStr, i, i+byteCount-1)
i = i + byteCount -1
end
if byteCount == 1 then
nWidth = nWidth + 1
table.insert(tName,char)
table.insert(tCode,1)
elseif byteCount >1 then
nWidth = nWidth + 2
table.insert(tName,char)
table.insert(tCode,2)
end
end
if nWidth >nMaxCount then
local _sN = “”
local _len = 0
for i=1,#tName do
_sN = _sN .. tName[i]
_len = _len + tCode[i]
if _len >= nShowCount then
break
end
end
sName = _sN .. “...”
end
return sName
end
文档为doc格式