您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

在处理中文字符串的时候,如何处理�这个字符

2024/3/26 6:18:37发布18次查看
在处理一些爬下来的网页时,经常发现会存在�这个字符。尝试各种转编码,无果。
比如:
每个人对工� �的使用往往各有偏好

对应的原文是这个:
每个人对工具的使用往往各有偏好

如何处理这样的情况,这又是由于什么问题产生的呢?
如果需要资料,貌似这个可以看看
http://apps.timwhitlock.info/unicode/inspect?s=%ef%bf%bd
回复内容: 在处理一些爬下来的网页时,经常发现会存在�这个字符。尝试各种转编码,无果。
比如:
每个人对工� �的使用往往各有偏好

对应的原文是这个:
每个人对工具的使用往往各有偏好

如何处理这样的情况,这又是由于什么问题产生的呢?
如果需要资料,貌似这个可以看看
http://apps.timwhitlock.info/unicode/inspect?s=%ef%bf%bd
从某编码向unicode编码转化时,如果没有对应的字符,得到的将是unicode的代码“\uffffd”,也就是�这个字符。
这个是你的爬虫根本不识别原网页的编码格式(ascii或者gb2312等)和压缩格式(gzip等),全都无脑转成utf-8字符串导致的,出现这个字符说明转换失败,数据已经丢失了,这个字符本身并没什么实际意义。
如果是php的话,这个可能是因为substring导致的。解决办法是安装mb_string模块,使用mb_*系列函数。
有时候一个汉字被截掉一部分会产生这个符号,比如一个两字节的汉子被截掉了一字节,怎么处理我也不知道。。。
你这个应该是‘具’字被分成两部分了。。
public static function utf8substr($str, $from, $len){ return preg_replace('#^(?:[\x00-\x7f]|[\xc0-\xff][\x80-\xbf]+){0,'.$from.'}'. '((?:[\x00-\x7f]|[\xc0-\xff][\x80-\xbf]+){0,'.$len.'}).*#s', '$1',$str);}
这个问题我估计是因为这段文字在换行的时候被截断了,你扒文字的时候注意看看换行符有没有把一个文字分成两半
可能它就是乱码
你可以用浏览器正常访问一下试试
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product