在处理一些爬下来的网页时,经常发现会存在�
这个字符。尝试各种转编码,无果。
比如:
每个人对工� �的使用往往各有偏好
对应的原文是这个:
每个人对工具的使用往往各有偏好
如何处理这样的情况,这又是由于什么问题产生的呢?
如果需要资料,貌似这个可以看看
在处理一些爬下来的网页时,经常发现会存在�
这个字符。尝试各种转编码,无果。
比如:
每个人对工� �的使用往往各有偏好
对应的原文是这个:
每个人对工具的使用往往各有偏好
如何处理这样的情况,这又是由于什么问题产生的呢?
如果需要资料,貌似这个可以看看
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);
}
1 回答4.1k 阅读✓ 已解决
3 回答1.9k 阅读✓ 已解决
2 回答2.2k 阅读✓ 已解决
2 回答2.2k 阅读
1 回答1.4k 阅读✓ 已解决
798 阅读
1 回答331 阅读✓ 已解决
从某编码向Unicode编码转化时,如果没有对应的字符,得到的将是Unicode的代码“\uffffd”,也就是
�
这个字符。这个是你的爬虫根本不识别原网页的编码格式(ASCII或者GB2312等)和压缩格式(Gzip等),全都无脑转成UTF-8字符串导致的,出现这个字符说明转换失败,数据已经丢失了,这个字符本身并没什么实际意义。