`

PHP 不区分中英文截取utf8字符串

阅读更多
<?php
header('Content-Type: text/html; charset=utf-8');
//截取utf8字符串
function utf8Substr($str='', $start=0, $len=10)
{
    return preg_replace('#^(?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,'.$start.'}'.
        '((?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,'.$len.'}).*#s',
        '$1',$str);
}
echo utf8Substr('阅谁问君诵,水落清香浮。',8,2),PHP_EOL;
echo utf8Substr('吴者然onestopweb');

 

效果图:

 

 

 

 

 

 

 

 

 

 

 

  • 大小: 10.9 KB
1
0
分享到:
评论

相关推荐

    高效中英文字符串截取方法

    ### 高效中英文字符串截取方法 #### 知识点概述 本文将详细介绍一种用于高效截取中英文混合字符串的方法。该方法适用于处理大量数据(例如10万条记录),能够在极短的时间内(例如1秒)完成所需的操作。这种方法...

    PHP UTF-8 等宽度截取中英文字符.txt

    示例代码中定义了`u8_title_substr`函数,通过循环遍历字符串中的每个字符,根据字符的编码类型(1、2、3或4字节)累加相应的权重值,最终实现了等宽度截取UTF-8编码的中英文字符的功能。 #### 五、注意事项 - 在...

    PHP中如何截取中文字符串

    中文字符串通常包含UTF-8编码的字符,这与ASCII编码的英文字符串处理方式有所不同。以下将详细讲解如何在PHP中正确截取中文字符串。 首先,我们需要了解UTF-8编码的特点。UTF-8是一种变长的字符编码,英文字符由一...

    以utf8格式截取的字符串编码

    在PHP中,可以使用`mb_strcut`函数来安全地截取UTF-8字符串。`mb_strcut`是多字节字符串函数,它允许我们指定字符串的起始位置和长度,以正确地处理非ASCII字符。例如: ```php $text = "你好,世界!这是一个UTF-8...

    C++中英混合字符串截取

    这个示例首先将UTF-8字符串转换为宽字符串,然后遍历每个字符,如果遇到非字母字符(可能是汉字),则计算其字节长度,并相应调整截取位置。最后,将截取后的宽字符串再转换回UTF-8。 在实际项目中,可能还需要考虑...

    C#区分中英文按照指定长度截取字符串的方法

    本文实例讲述了C#区分中英文按照指定长度截取字符串的方法。分享给大家供大家参考。具体如下: 这段C#代码用于按照指定的长度截取字符串,一个中文字符算2个字符,按照这个方法截取的字符串基本可以保持显示长度一致...

    java中截取带汉字的字符串

    ### Java中截取带汉字的字符串 在Java编程语言中,处理包含中文字符的字符串时,经常遇到的一个问题是如何正确地截取这些字符串。如果直接按照字节(byte)来进行分割,很容易导致中文字符被截断一半,从而形成乱码。...

    JavaScript截取中文字符串

    假设有一个包含中英文混合的字符串`"Hello, 你好!"`,现在希望截取前5个字符(其中中文字符按两个字符计): ```javascript var str = "Hello, 你好!"; var result = subString(str, 5, true); console.log(result)...

    java中英文字符串截取

    ### Java中英文字符串截取的关键点 1. **字符编码的影响**:中文字符在不同的编码方式下占用的字节数不同。例如,在UTF-8编码中,中文字符通常占用3个字节,而在GBK编码中,则可能占用2或4个字节。因此,在计算字符...

    统计字符串中英文标点数量并截取.zip

    这个压缩包内包含的可能是Java代码示例(如csdn-demo),用于批量处理字符串,统计其中的中英文标点符号的数量,并根据指定的字符编码(GBK或UTF)来计算字符串的总长度。如果字符串的总长度超过预设的最大长度,...

    [待删除]字符串截取 - 中英文

    根据给定文件的信息,我们将深入探讨Java中字符串截取的原理、方法以及在中英文操作系统下的特殊处理。 ### Java字符串截取 #### 原理与实现 在Java中,字符串本质上是一个不可变的字符序列,由`char`类型的数组...

    解析使用substr截取UTF-8中文字符串出现乱码的问题

    在PHP中,`strlen()` 函数用于获取字符串的长度,但它并不区分字符编码,仅计算字节个数。而对于`mb_strlen()`函数,它能够正确地计算出基于UTF-8编码的实际字符个数,因为它属于多字节字符串函数(multibyte string...

    关于java按字节截取带有汉字的字符串的解法

    在Java编程语言中,处理带有汉字的字符串时,由于汉字占据多个字节,按照字节进行截取可能会导致汉字被不完整地分割,从而产生乱码。为了解决这个问题,我们需要理解Unicode编码以及如何在Java中正确处理多字节字符...

    php截取字符串之截取utf8或gbk编码的中英文字符串示例

    本示例主要探讨如何正确地截取UTF-8和GBK编码的中英文字符串,以适应特定的需求,例如微博的字数限制规则。 首先,我们要明白PHP内置的`strlen()`函数用于计算字符串的字节数,而非字符数。对于UTF-8编码的中文字符...

    Java精确截取字符串.pdf

    在处理多语言混合的字符串时,可能需要使用UTF-8等其他编码方式,同时考虑到不同语言字符的字节长度差异。此外,还可以使用Java的`Character`类的`isHighSurrogate()`和`isLowSurrogate()`方法来处理Unicode字符,以...

    截取如下字符串“java程序教程”的前5个字节,字符串应该为“java程”,截取前6个字符,字符串也应该为“java程”,程序实现之.

    题目中提到“截取前5个字节, 字符串应该为‘java程’”,意味着我们需要理解,在UTF-8编码格式下,英文字符通常占用1个字节,而中文字符则占用3个字节。因此,实际上,从“java程序教程”中截取前5个字节,得到的...

    php 截取utf-8格式的字符串实例代码

    代码示例中定义了一个函数`truncate_utf8_string`,该函数接收三个参数:要截取的字符串`$string`,截取长度`$length`,以及如果字符串长度不足截取长度时附加到截取字符串末尾的字符串`$etc`。 函数的工作原理如下...

    php 截取中英文混合字符串的方法

    标准的`substr`函数对于UTF-8编码的字符串并不适用,因为它会简单地按照字节来截取,这可能导致截取的结果不准确,特别是对于中文字符这种多字节编码的情况。为了解决这个问题,我们需要使用更加智能的方法,例如`...

    LabVIEW拆分中文字符串.rar

    在LabVIEW中处理字符串,尤其是中文字符串,有时会涉及到特殊的技巧和注意事项,因为中文字符是多字节的,与英文等单字节字符处理方式有所不同。这个"LabVIEW拆分中文字符串.rar"文件很可能是提供了一个解决此类问题...

Global site tag (gtag.js) - Google Analytics