substr截取字符串,shell截取字符串最后两位
各位老铁们,大家好,今天由我来为大家分享substr截取字符串,以及shell截取字符串最后两位的相关问题知识,希望对大家有所帮助。如果可以帮助到大家,还望关注收藏下本站,您的支持是我们最大的动力,谢谢大家了哈,下面我们开始吧!
JavaScript字符串对象substr方法入门实例(用于截取字符串)
javascript中截取字符串的实现方法如下:
1、使用substr()函数:substr()方法可在字符串中抽取从start下标开始的指定数目的字符。
varstr="Helloworld!"
;//定义字符串document.write(str.substr(3))
;//打印截取后的结果从第三位开始到最后输出结果如下:loworld!如果是写成指定起始位和长度就会按照指定的长度输出:
document.write(str.substr(3,5));输出结果:lowo2、利用substring()函数:substring()方法用于提取字符串中介于两个指定下标之间的字符。
varstr="Helloworld!"
;document.write(str.substr(3))
;输出结果如下:loworld!如果是写成指定起始位和长度就会按照指定的长度输出:
document.write(str.substr(3,7))
;输出结果:low
JS截取指定字符串到指定字符串之间的内容
varstr="<123>asdadsadsa<456>";
str=str.match(/<123>(\S*)<456>/)[1];
console.log(str);
\S:匹配任何非空白字符。
*:匹配前面的子表达式零次或多次。
match方法:
语法:
stringObject.match(searchvalue)
stringObject.match(regexp)
searchvalue:必需。规定要检索的字符串值。
regexp:必需。规定要匹配的模式的 RegExp对象。如果该参数不是 RegExp对象,则需要首先把它传递给 RegExp构造函数,将其转换为 RegExp对象。
如果 regexp没有标志 g,那么 match()方法就只能在 stringObject中执行一次匹配。如果没有找到任何匹配的文本, match()将返回 null。否则,它将返回一个数组。
例如:
"186a619b28".match(/\d+/g);
如果上面的匹配不是全局匹配,那么得到的结果如下:
["186", index: 0, input:"186a619b28"]。
扩展资料:
常用的正则字符
1、\:将下一个字符标记为一个特殊字符、或一个原义字符、或一个向后引用、或一个八进制转义符。
2、^:匹配输入字符串的开始位置。如果设置了 RegExp对象的 Multiline属性,^也匹配'n'或'r'之后的位置。
3、$:匹配输入字符串的结束位置。如果设置了RegExp对象的 Multiline属性,$也匹配'n'或'r'之前的位置。
4、+:匹配前面的子表达式一次或多次。
5、?:匹配前面的子表达式零次或一次。
6、{n}:n是一个非负整数。匹配确定的 n次。
7、{n,}:n是一个非负整数。至少匹配n次。
8、{n,m}:m和 n均为非负整数,其中n<= m。最少匹配 n次且最多匹配 m次。请注意在逗号和两个数之间不能有空格。
9、?:当该字符紧跟在任何一个其他限制符(*,+,?,{n},{n,},{n,m})后面时,匹配模式是非贪婪的。
非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。
PHP中使用substr截取字符串出现中文乱码问题该怎么办
在PHP程序开发中,经常会执行字符串的截取操作,比如输出信息列表时,标题不宜过长,打印文章摘要时,也要执行一系列的字符串截取操作。遇到这些需求时,我们经常会想到使用substr()方法来实现,substr()对全英文字符串的截取是比较适合的。
但字符串只要出现中文字符,就有可能导致PHP
substr中文乱码,因为中文UTF-8编码,每个汉字占3字节,而GB2312占2字节,英文占1字节,截取位数不准确,substr()硬生生地将
一个中文字符“锯”成两半,造成断开的字符会把其后的..拉过来一起做一个字,所以出现了PHP substr中文乱码。
substr---取得部份字符串
语法: string substr(string string, int start [, int length])
说明:
substr()传回 string的一部份字符串,由参数 start和 length指定。
如果 start是正数,传回的字符串将会从 string的第 start个字元开始。
Example:
<?php
$rest= substr("abcdef", 1);// returns"bcdef"
$rest= substr("abcdef", 1, 3);// returns"bcd"
?>
如果 start是负数,传回的字符串将会从 string结尾的第 start个字开始。
Example:
<?php
$rest= substr("abcdef",-1);// returns"f"
$rest= substr("abcdef",-2);// returns"ef"
$rest= substr("abcdef",-3, 1);// returns"d"
?>
如果有给予参数 length而且是正数时,传回的字符串将会从 start传回 length个字元。
如果有给予参数 length而且是负数时,传回的字符串将会结束于 string结尾的第 length个字元。
Example:
<?php
$rest= substr("abcdef", 1,-1);// returns"bcde"
?>
对于英文没有问题,我们测试一个中文
<?php
$rest= substr("中国人", 1,-1);// returns"fdsafsda"就是乱码了
?>
这种截取字符的结果,肯定不是我们想要的结果,这种出现PHP substr中文乱码的情况,可能会导致程序无法正常运行。解决办法主要有两种:
一、使用mbstring扩展库的mb_substr()截取就不会出现乱码了。
可以用mb_substr()/mb_strcut()这个函数,mb_substr()/mb_strcut()的用法与substr()相似,
只是在mb_substr()/mb_strcut最后要加入多一个参数,以设定字符串的编码,但是一般的服务器都没打开
php_mbstring.dll,需要在php.ini在把php_mbstring.dll打开。
<?php
echo mb_substr("php中文字符encode",0,4,"utf-8");
?>
如果未指定最后一个编码参数,会是三个字节为一个中文,这就是utf-8编码的特点,若加上utf-8字符集说明,所以,是以一个字为单位来截取的。
使用的时候要注意php文件的编码,和网页显示时的编码。使用这个mb_substr方法要事先知道字符串的编码,如果不知道编码,就需要判断,mbstring库还提供了mb_check_encoding来检验字符串编码,但还不完善。
PHP自带几种字符串截取函数,其中常用到的就是 substr和 mb_substr。前者在处理中文时,GBK为 2个长度单位,UTF为 3个长度单位,后者指定编码后,一个中文即为 1个长度单位。
substr有时会截 1/3个中文或半个中文,会显示乱码,相对来说 mb_substr更适合我们使用。不过有时候 mb_substr
就显得不那么好用了。例如我要显示一个小图片的简要信息,5个中文正好,超过 5个就截取前4再加上
”…”,这样处理中文是没问题了,可是处理英文或数字,这样截取就太短了。
二、自己书写截取函数,但效率不如用mbstring扩展库来得高。下面是ecshop里面的截取UTF-8编码下字符串的函数。
function sub_str($str,$length=,$append= true)
{
$str= trim($str);
$strlength= strlen($str);
if($length==||$length>=$strlength)
{
return$str;//截取长度等于或大于等于本字符串的长度,返回字符串本身
}
elseif($length<)//如果截取长度为负数
{
$length=$strlength+$length;//那么截取长度就等于字符串长度减去截取长度
if($length<)
{
$length=$strlength;//如果截取长度的绝对值大于字符串本身长度,则截取长度取字符串本身的长度
}
}
if(function_exists('mb_substr'))
{
$newstr= mb_substr($str,,$length, EC_CHARSET);
}
elseif(function_exists('iconv_substr'))
{
$newstr= iconv_substr($str,,$length, EC_CHARSET);
}
else
{
//$newstr= trim_right(substr($str,,$length));
$newstr= substr($str,,$length);
}
if($append&&$str!=$newstr)
{
$newstr.='...';
}
return$newstr;
}
关于substr截取字符串到此分享完毕,希望能帮助到您。