PHP通過(guò)iconv將字符串從GBK轉(zhuǎn)換為UTF8字符集
更新時(shí)間:2011年07月18日 00:29:17 作者:
PHP通過(guò)iconv將字符串從GBK轉(zhuǎn)換為UTF8字符集的方法,需要的朋友可以參考下。
1. iconv()介紹
iconv函數(shù)可以將一種已知的字符集文件轉(zhuǎn)換成另一種已知的字符集文件。例如:從GB2312轉(zhuǎn)換為UTF-8。
iconv函數(shù)在php5中內(nèi)置,GB字符集默認(rèn)打開(kāi)。
2. iconv()錯(cuò)誤
iconv在轉(zhuǎn)換字符”—”到gb2312時(shí)會(huì)出錯(cuò),解決方法是在需要轉(zhuǎn)成的編碼后加 “//IGNORE”,也就是iconv函數(shù)第二個(gè)參數(shù)后.如下:
iconv("UTF-8", "GB2312//IGNORE", $data)
ignore的意思是忽略轉(zhuǎn)換時(shí)的錯(cuò)誤,如果沒(méi)有ignore參數(shù),所有該字符后面的字符串都無(wú)法被保存。
3. iconv()例子
例1:
<?php
echo $str= ‘你好,這里是賣(mài)咖啡!';
echo '<br />';
echo iconv('GB2312', 'UTF-8', $str); //將字符串的編碼從GB2312轉(zhuǎn)到UTF-8
echo '<br />';
echo iconv_substr($str, 1, 1, 'UTF-8'); //按字符個(gè)數(shù)截取而非字節(jié)
print_r(iconv_get_encoding()); //得到當(dāng)前頁(yè)面編碼信息
echo iconv_strlen($str, 'UTF-8'); //得到設(shè)定編碼的字符串長(zhǎng)度
?>
例2:
如果你的PHP文件是UTF-8編碼的,那么下面的代碼就可以正確輸出:
<?php
$str='我愛(ài)百度';
$utf='';
for ($i=0;$i<strlen($str);$i++) $utf.=sprintf("%%%02X",ord(substr($str,$i,1)));
echo $utf;
?>
如果你的PHP文件是GB的,那么下面的代碼可以工作:
<?php
$str='我愛(ài)百度';
$str=iconv("GBK", "UTF-8", $str);
$utf='';
for ($i=0;$i<strlen($str);$i++) $utf.=sprintf("%%%02X",ord(substr($str,$i,1)));
echo $utf;
?>
以上情況下,程序輸出的內(nèi)容是:
%E6%88%91%E7%88%B1%E7%99%BE%E5%BA%A6
iconv函數(shù)可以將一種已知的字符集文件轉(zhuǎn)換成另一種已知的字符集文件。例如:從GB2312轉(zhuǎn)換為UTF-8。
iconv函數(shù)在php5中內(nèi)置,GB字符集默認(rèn)打開(kāi)。
2. iconv()錯(cuò)誤
iconv在轉(zhuǎn)換字符”—”到gb2312時(shí)會(huì)出錯(cuò),解決方法是在需要轉(zhuǎn)成的編碼后加 “//IGNORE”,也就是iconv函數(shù)第二個(gè)參數(shù)后.如下:
復(fù)制代碼 代碼如下:
iconv("UTF-8", "GB2312//IGNORE", $data)
ignore的意思是忽略轉(zhuǎn)換時(shí)的錯(cuò)誤,如果沒(méi)有ignore參數(shù),所有該字符后面的字符串都無(wú)法被保存。
3. iconv()例子
例1:
復(fù)制代碼 代碼如下:
<?php
echo $str= ‘你好,這里是賣(mài)咖啡!';
echo '<br />';
echo iconv('GB2312', 'UTF-8', $str); //將字符串的編碼從GB2312轉(zhuǎn)到UTF-8
echo '<br />';
echo iconv_substr($str, 1, 1, 'UTF-8'); //按字符個(gè)數(shù)截取而非字節(jié)
print_r(iconv_get_encoding()); //得到當(dāng)前頁(yè)面編碼信息
echo iconv_strlen($str, 'UTF-8'); //得到設(shè)定編碼的字符串長(zhǎng)度
?>
例2:
如果你的PHP文件是UTF-8編碼的,那么下面的代碼就可以正確輸出:
復(fù)制代碼 代碼如下:
<?php
$str='我愛(ài)百度';
$utf='';
for ($i=0;$i<strlen($str);$i++) $utf.=sprintf("%%%02X",ord(substr($str,$i,1)));
echo $utf;
?>
如果你的PHP文件是GB的,那么下面的代碼可以工作:
復(fù)制代碼 代碼如下:
<?php
$str='我愛(ài)百度';
$str=iconv("GBK", "UTF-8", $str);
$utf='';
for ($i=0;$i<strlen($str);$i++) $utf.=sprintf("%%%02X",ord(substr($str,$i,1)));
echo $utf;
?>
以上情況下,程序輸出的內(nèi)容是:
%E6%88%91%E7%88%B1%E7%99%BE%E5%BA%A6
您可能感興趣的文章:
- PHP中文處理 中文字符串截取(mb_substr)和獲取中文字符串字?jǐn)?shù)
- PHP preg_replace() 正則替換所有符合條件的字符串
- php中利用explode函數(shù)分割字符串到數(shù)組
- PHP字符轉(zhuǎn)義相關(guān)函數(shù)小結(jié)(php下的轉(zhuǎn)義字符串)
- php字符串截取的簡(jiǎn)單方法
- PHP中去掉字符串首尾空格的方法
- php 字符串中是否包含指定字符串的多種方法
- PHP 查找字符串常用函數(shù)介紹
- php字符串截取問(wèn)題
- PHP字符串的連接的簡(jiǎn)單實(shí)例
- php學(xué)習(xí)筆記之字符串常見(jiàn)操作總結(jié)
相關(guān)文章
PHP curl 獲取響應(yīng)的狀態(tài)碼的方法
PHP curl可以從服務(wù)器端模擬一個(gè)http請(qǐng)求,例如抓取網(wǎng)頁(yè)、模擬登陸等,想要獲取狀態(tài)碼,需要在執(zhí)行curl_exec后再通過(guò)curl_getinfo來(lái)獲取2014-01-01PHP遞歸統(tǒng)計(jì)系統(tǒng)中代碼行數(shù)
這篇文章主要為大家詳細(xì)介紹了PHP遞歸統(tǒng)計(jì)系統(tǒng)中代碼行數(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09php操作Redis數(shù)據(jù)庫(kù)基本示例【安裝、連接、設(shè)置、查詢、斷開(kāi)】
這篇文章主要介紹了php操作Redis數(shù)據(jù)庫(kù)的方法,較為詳細(xì)的分析了redis擴(kuò)展的安裝、php連接redis、設(shè)置、查詢及斷開(kāi)redis相關(guān)實(shí)現(xiàn)技巧與操作注意事項(xiàng),需要的朋友可以參考下2023-07-07php使用include 和require引入文件的區(qū)別
require()語(yǔ)句的性能與include()相類似,都是包括并運(yùn)行指定文件。不同之處在于:對(duì)include()語(yǔ)句來(lái)說(shuō),在執(zhí)行文件時(shí)每次都要進(jìn)行讀取和評(píng)估;而對(duì)于require()來(lái)說(shuō),文件只處理一次(實(shí)際上,文件內(nèi)容替換require()語(yǔ)句)。2017-02-02php函數(shù)實(shí)現(xiàn)判斷是否移動(dòng)端訪問(wèn)
本文給大家分享的是一則php判斷是否移動(dòng)端訪問(wèn)的函數(shù),是之前收藏的,這里發(fā)出來(lái),推薦給小伙伴們。2015-03-03PHP文件上傳利用的常見(jiàn)函數(shù)總結(jié)大全
文件上傳是開(kāi)發(fā)中常見(jiàn)的一個(gè)功能,下面這篇文章主要給大家介紹了關(guān)于PHP文件上傳利用的常見(jiàn)函數(shù),文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-03-03