`
aiou
  • 浏览: 194907 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

php截取等长UFT8中英文混合字串

    博客分类:
  • php
PHP 
阅读更多
第一次发博,呵呵。
原创,转载请标明出处。

由于需要,想实现“php截取等长UFT8中英文混合字串”,可是网上找了很多代码不是有乱码就是不能实现等长(以一个中文长度为单位,两个英文字母算一个长度,如‘等长’长度为2,‘UTF8’长度也是2)。

由于utf8编码时,中文为三个字节,英文为一个字节,用substr就会出现乱码,用mb_substr会出现上面的不等长问题,但不会有乱码;

我以字节为单位进行操作,简单实现了一个小程序。
只能在utf8编码是使用。

/*utf8编码时截取等长中英文字串*/ //英文标点[.,\"\\?!:_']
<?
function substr_utf8($string,$start,$length)
{       //by aiou
	 $chars = $string;
	 //echo $string[0].$string[1].$string[2];
	 $i=0;
	 do{
	 	if (preg_match ("/[0-9a-zA-Z]/", $chars[$i])){//纯英文
	 		$m++;
	 	}
	else {$n++;	 	}//非英文字节,
	 	$k = $n/3+$m/2;
	 	$l = $n/3+$m;//最终截取长度;$l = $n/3+$m*2?
		$i++;
	} while($k < $length);
	 $str1 = mb_substr($string,$start,$l,'utf-8');//保证不会出现乱码
	 return $str1;
}

测试结果:
$string = '第一次截取,mb_substr返回的是字符串宽度是按“字”来计算';
$string1 = '第一次截取,返回的是字符串宽度是按“字”来计算';
$string2 = '第A一D次截取,返回的12345是字符串宽度是按“字”来计算';


1.
echo substr_utf8($string,0,1).'<br/>';
echo substr_utf8($string,0,2).'<br/>';
echo substr_utf8($string,0,3).'<br/>';
echo substr_utf8($string,0,4).'<br/>';
echo substr_utf8($string,0,5).'<br/>';
echo substr_utf8($string,0,6).'<br/>';
echo substr_utf8($string,0,7).'<br/>';
echo substr_utf8($string,0,8).'<br/>';
echo substr_utf8($string,0,9).'<br/>';
echo substr_utf8($string,0,10).'<br/>';
echo substr_utf8($string,0,11).'<br/>';
echo substr_utf8($string,0,12).'<br/>';
echo substr_utf8($string,0,13).'<br/>';
echo substr_utf8($string,0,14).'<br/>';
echo substr_utf8($string,0,15).'<br/>';
echo substr_utf8($string,0,16).'<br/>';
echo substr_utf8($string,0,17).'<br/>';
echo substr_utf8($string,0,18).'<br/>';
echo substr_utf8($string,0,19).'<br/>';
echo substr_utf8($string,0,20).'<br/>';


第一
第一次
第一次截
第一次截取
第一次截取,
第一次截取,mb
第一次截取,mb_s
第一次截取,mb_sub
第一次截取,mb_subst
第一次截取,mb_substr
第一次截取,mb_substr返
第一次截取,mb_substr返回
第一次截取,mb_substr返回的
第一次截取,mb_substr返回的是
第一次截取,mb_substr返回的是字
第一次截取,mb_substr返回的是字符
第一次截取,mb_substr返回的是字符串
第一次截取,mb_substr返回的是字符串宽
第一次截取,mb_substr返回的是字符串宽度

2.
echo substr_utf8($string1,0,5).'<br/>';
echo substr_utf8($string1,0,6).'<br/>';
echo substr_utf8($string1,0,7).'<br/>';
echo substr_utf8($string1,0,8).'<br/>';
echo substr_utf8($string1,0,9).'<br/>';
echo substr_utf8($string1,0,10).'<br/>';
echo substr_utf8($string1,0,11).'<br/>';
echo substr_utf8($string1,0,12).'<br/>';
echo substr_utf8($string1,0,13).'<br/>';
echo substr_utf8($string1,0,14).'<br/>';
echo substr_utf8($string1,0,15).'<br/>';
echo substr_utf8($string1,0,16).'<br/>';
echo substr_utf8($string1,0,17).'<br/>';
echo substr_utf8($string1,0,18).'<br/>';
echo substr_utf8($string1,0,19).'<br/>';
echo substr_utf8($string1,0,20).'<br/>';

第一次截取
第一次截取,
第一次截取,返
第一次截取,返回
第一次截取,返回的
第一次截取,返回的是
第一次截取,返回的是字
第一次截取,返回的是字符
第一次截取,返回的是字符串
第一次截取,返回的是字符串宽
第一次截取,返回的是字符串宽度
第一次截取,返回的是字符串宽度是
第一次截取,返回的是字符串宽度是按
第一次截取,返回的是字符串宽度是按“
第一次截取,返回的是字符串宽度是按“字
第一次截取,返回的是字符串宽度是按“字”

3.
echo substr_utf8($string2,0,5).'<br/>';
echo substr_utf8($string2,0,6).'<br/>';
echo substr_utf8($string2,0,7).'<br/>';
echo substr_utf8($string2,0,8).'<br/>';
echo substr_utf8($string2,0,9).'<br/>';
echo substr_utf8($string2,0,10).'<br/>';
echo substr_utf8($string2,0,11).'<br/>';
echo substr_utf8($string2,0,12).'<br/>';
echo substr_utf8($string2,0,13).'<br/>';
echo substr_utf8($string2,0,14).'<br/>';
echo substr_utf8($string2,0,15).'<br/>';
echo substr_utf8($string2,0,16).'<br/>';
echo substr_utf8($string2,0,17).'<br/>';
echo substr_utf8($string2,0,18).'<br/>';
echo substr_utf8($string2,0,19).'<br/>';
echo substr_utf8($string2,0,20).'<br/>';

第A一D次截
第A一D次截取
第A一D次截取,
第A一D次截取,返
第A一D次截取,返回
第A一D次截取,返回的
第A一D次截取,返回的12
第A一D次截取,返回的1234
第A一D次截取,返回的12345
第A一D次截取,返回的12345是
第A一D次截取,返回的12345是字
第A一D次截取,返回的12345是字符
第A一D次截取,返回的12345是字符串
第A一D次截取,返回的12345是字符串宽
第A一D次截取,返回的12345是字符串宽度
第A一D次截取,返回的12345是字符串宽度是

4.
$ss='1234567890abcdefghijklmnopqrst';
echo Utf8Helper::substr_utf8($ss,0,1).'<br/>';
echo Utf8Helper::substr_utf8($ss,0,2).'<br/>';
echo Utf8Helper::substr_utf8($ss,0,3).'<br/>';
echo Utf8Helper::substr_utf8($ss,0,4).'<br/>';
echo Utf8Helper::substr_utf8($ss,0,5).'<br/>';
echo Utf8Helper::substr_utf8($ss,0,6).'<br/>';
echo Utf8Helper::substr_utf8($ss,0,7).'<br/>';         
echo Utf8Helper::substr_utf8($ss,0,8).'<br/>';         
echo Utf8Helper::substr_utf8($ss,0,9).'<br/>';         
echo Utf8Helper::substr_utf8($ss,0,10);

12
1234
123456
12345678
1234567890
1234567890ab
1234567890abcd
1234567890abcdef
1234567890abcdefgh
1234567890abcdefghij

长度都以汉字数为基准。
基本上每两个英文字母、数字、英文标点算作一个汉字长度。看上去效果还不错。
改进一下还可以做其它编码下的。
效率没做测试,还没有这概念。
o(∩_∩)o...
2
0
分享到:
评论
1 楼 huixia0010 2013-05-31  
感谢分享,已经转载到了我的博客,并附上了本文链接,非常感谢

相关推荐

    UFT中文帮助文档

    **UFT(Unified Functional Testing)**,全称统一功能测试,是Micro Focus公司推出的一款强大的自动化测试工具,尤其适用于企业级的功能测试和回归测试。它支持多种应用类型,包括Web、桌面、移动以及各种企业级...

    UFT英文帮助文档

    【UFT英文帮助文档】是HP(现已被Micro Focus收购)Unified Functional Testing(UFT,统一功能测试)软件的详尽指南,版本为11.50。该文档旨在为用户提供在Windows操作系统环境下进行自动化功能测试的指导。文档...

    ECSHOP2.7.0-UFT8模板

    ECSHOP2.7.0-UFT8模板包中包含19个不同的模板,这些模板设计多样,为商家提供了丰富的界面选择,以适应不同类型的在线商店需求。模板的设计不仅关乎网站的美观,更影响用户体验和转化率,因此选择一个与品牌形象相符...

    js将中文转换成UFT8

    对于英文字符,UTF-8使用单字节表示,而对于中文等复杂字符,可能需要2到4个字节。这种编码方式在全球化背景下广泛应用,因为它能够兼容多种语言,包括中文。 在JavaScript中,字符串是以Unicode编码存储的,这意味...

    xml格式转换uft8工具

    将xml格式数据转换为uft8编码的xml数据,主要用于接口测试时,传递xml数据时,需要uft-8格式的xml数据,方便于测试人员的一个小工具

    UFT_12.01_UserGuide_中文用户手册.pdf

    文档介绍了UFT的多个特性,包括UFT的GUI测试、API测试、集成测试、业务流程测试等。此外,手册还提供了如何使用UFT进行应用程序分析、测试基础结构准备、测试步骤添加、测试增强、测试运行调试以及运行结果分析和...

    基于PHP的盘锦DJ舞曲网PHP版UFT-8源码.zip

    【标题】"基于PHP的盘锦DJ舞曲网PHP版UFT-8源码.zip" 涉及的核心技术是PHP编程语言以及UTF-8字符编码标准,这是一款专为盘锦DJ舞曲网站设计的后台管理系统源码。在本文中,我们将深入探讨PHP在Web开发中的应用,UTF-...

    基于PHP的盘锦DJ舞曲网 PHP版UFT-8.zip

    【标题】"基于PHP的盘锦DJ舞曲网 PHP版UFT-8.zip"是一个针对盘锦地区的在线DJ舞曲服务平台的源代码包,它采用了PHP编程语言进行开发,并且编码格式为UTF-8。这个项目可能包含了实现网站功能的所有必要文件,包括但不...

    UFT11.5使用指南中文完整版(.doc)

    UFT11.5中文完整版(.doc),介绍的很全面 支持跳转 复制粘贴

    UFT14.52下载地址.zip

    在功能测试方面,UFT提供了丰富的功能,能够模拟用户的各种操作,如点击、输入文本、选择下拉菜单等,覆盖了各种应用类型,包括桌面应用、Web应用和移动应用。它支持多种应用程序接口(API),如GUI、Web服务以及...

    UFT录制简单的视频

    【UFT录制简单的视频】 UFT,全称Unified Functional Testing,是...在实际工作中,UFT的强大之处还在于其对各种应用程序和技术的支持,包括桌面应用、Web应用、移动应用等,以及对测试框架和第三方工具的集成能力。

    恒生UFT介绍文档

    此外,UFT系统还具备高可用性,确保了交易过程中的安全性与稳定性。 ##### 内存数据库技术 UFT系统采用了自主研发的全内存数据库技术。这种技术通过多重索引和高效的事务管理机制,大幅提升了数据处理的速度与效率...

    xml转换uft-8格式工具(32位)

    将xml格式数据转换为uft-8格式的字符串数据,主要用于接口测试时,传递xml数据时,需要uft-8格式的xml数据,方便于测试人员的一个小工具

    PHP实例开发源码-盘锦DJ舞曲网 PHP版UFT-8.zip

    《PHP实例开发源码——盘锦DJ舞曲网 PHP版UFT-8》是一个实际的PHP项目源码,主要用于展示如何使用PHP语言构建一个在线音乐分享平台,特别是针对DJ舞曲。这个项目采用UTF-8编码,确保了多语言字符集的正确显示,符合...

    UFT(QTP)12.01教程

    标题中提到的“UFT(QTP)12.01教程”是一个关于软件自动化测试的教程,主要面向初学者。这里的UFT指的是HP Unified Functional Testing,原名Quick Test Professional(QTP),是惠普公司开发的一款功能测试工具,...

    中国汉字uft-8码+GB2312+全拼

    中国6000多字的utf-8码 +GB2312码和全拼

    UFT_API 接口测试

    UFT支持多种类型的测试,包括GUI测试、回归测试、数据驱动测试等,并且可以测试多种应用程序,如传统的桌面应用程序、Web应用程序以及移动应用程序。 API(Application Programming Interface,应用程序编程接口)...

    网趣网上购物系统(uft-8)英文版

    网趣网上购物系统英文版采用uft-8国际标准编码设计开发,可用于全球任何服务器,完全英文化使用界面,具有功能强大、安全性高、可扩展性强等特点,支持Paypal等多种在线支付于一体,强大的SEO优化设置与搜索引擎紧密...

    CWPS通行证会员系统v1.6.1203UFT8简体中文版PHP5源码之家PHP源码会员交友

    CWPS通行证会员系统v1.6.1203UFT8是一款基于PHP5开发的会员管理系统,专为实现网站用户注册、登录、权限管理等功能而设计。此系统以其简体中文界面和易于理解的代码结构,为开发者提供了一个理想的平台,以便进行二...

    UFT_12.01_UserGuide_中文版

    QTP针对GUI应用程序包括传统的Windows应用程序以及现在越来越流行的Web应用,不仅适用于开发早期中,而且对于存在大量重复性的手工测试的项目、测试时间比较长的项目、回归测试等流程中具有绝对的优势。

Global site tag (gtag.js) - Google Analytics