本文目錄一覽:
- 1、php中如何將string類型轉換為date類型插入到資料庫中的date類型欄位中,incorrec
- 2、PHP符串處理函數
- 3、php中編碼轉換問題
- 4、PHP字元串轉數字
- 5、怎樣在PHP中把16進位HEX數據轉換為2進位數據呢?
- 6、php 里 mb_convert_encoding()函數,
php中如何將string類型轉換為date類型插入到資料庫中的date類型欄位中,incorrec
mysql 的時期格式可以直接插入字元串,
不過要符合這種格式 2000-01-01 00:00:00
把你的字元串弄成這種樣子可以直接存進去了
INSERT INTO `table_name` (`date`) VALUES (‘2000-01-01 00:00:00’);
“incorrect date value”: 不正確的日期值.
有時間字元串輸入格式是
2000-1-1
可以按以下方式處理
$strDate = ‘2000-1-1’;
$arr = explode(‘-‘,$strDate);
// 按 “-” 分隔成數組,也可以是其它的分隔符
$time = mktime(0,0,0,$arr[1],$arr[2],$arr[0]);
// 根據數組中的三個數據生成UNIX時間戳mktime(時,分,秒,月,日,年)
$fmtDate = date(‘Y-m-d H:i:s’, $time);
// 按Y-m-d H:i:s(年-月-日 時:分:秒)格式化
經過以上4行代碼;
可以把字元串 $strDate (2000-1-1)
轉換成 $fmtDate (2000-01-01 00:00:00)這種格式.
夠詳細了吧?
PHP符串處理函數
PHP5字元串處理函數
addcslashes — 為字元串裡面的部分字元添加反斜線轉義字元
addslashes — 用指定的方式對字元串裡面的字元進行轉義
bin2hex — 將二進位數據轉換成十六進位表示
chop — rtrim() 的別名函數
chr — 返回一個字元的ASCII碼
chunk_split — 按一定的字元長度將字元串分割成小塊
convert_cyr_string — 將斯拉夫語字元轉換為別的字元
convert_uudecode — 解密一個字元串
convert_uuencode — 加密一個字元串
count_chars — 返回一個字元串裡面的字元使用信息
crc32 — 計算一個字元串的crc32多項式
crypt — 單向散列加密函數
echo — 用以顯示一些內容
explode — 將一個字元串用分割符轉變為一數組形式
fprintf — 按照要求對數據進行返回,並直接寫入文檔流
get_html_translation_table — 返回可以轉換的HTML實體
hebrev — 將Hebrew編碼的字元串轉換為可視的文本
hebrevc — 將Hebrew編碼的字元串轉換為可視的文本
html_entity_decode — htmlentities ()函數的反函數,將HTML實體轉換為字元
htmlentities — 將字元串中一些字元轉換為HTML實體
htmlspecialchars_decode — htmlspecialchars()函數的反函數,將HTML實體轉換為字元
htmlspecialchars — 將字元串中一些字元轉換為HTML實體
implode — 將數組用特定的分割符轉變為字元串
join — 將數組轉變為字元串,implode()函數的別名
levenshtein — 計算兩個詞的差別大小
localeconv — 獲取數字相關的格式定義
ltrim — 去除字元串左側的空白或者指定的字元
md5_file — 將一個文件進行MD5演算法加密
md5 — 將一個字元串進行MD5演算法加密
metaphone — 判斷一個字元串的發音規則
money_format — 按照參數對數字進行格式化的輸出
nl_langinfo — 查詢語言和本地信息
nl2br — 將字元串中的換行符「n」替換成「
」
number_format — 按照參數對數字進行格式化的輸出
ord — 將一個ASCII碼轉換為一個字元
parse_str — 把一定格式的字元串轉變為變數和值
print — 用以輸出一個單獨的值
printf — 按照要求對數據進行顯示
quoted_printable_decode — 將一個字元串加密為一個8位的二進位字元串
quotemeta — 對若干個特定字元進行轉義
rtrim — 去除字元串右側的空白或者指定的字元
setlocale — 設置關於數字,日期等等的本地格式
sha1_file — 將一個文件進行SHA1演算法加密
sha1 — 將一個字元串進行SHA1演算法加密
similar_text — 比較兩個字元串,返回系統認為的相似字元個數
soundex — 判斷一個字元串的發音規則
sprintf — 按照要求對數據進行返回,但是不輸出
sscanf — 可以對字元串進行格式化
str_ireplace — 像str_replace()函數一樣匹配和替換字元串,但是不區分大小寫
str_pad — 對字元串進行兩側的補白
str_repeat — 對字元串進行重複組合
str_replace — 匹配和替換字元串
str_rot13 — 將字元串進行ROT13加密處理
str_shuffle — 對一個字元串裡面的字元進行隨機排序
str_split — 將一個字元串按照字元間距分割為一個數組
str_word_count — 獲取字元串裡面的英文單詞信息
strcasecmp — 對字元串進行大小比較,不區分大小寫
strchr — 通過比較返回一個字元串的部分strstr()函數的別名
strcmp — 對字元串進行大小比較
strcoll – 根據本地設置對字元串進行大小比較
strcspn — 返回字元連續非匹配長度的值
strip_tags — 去除一個字元串裡面的HTML和PHP代碼
stripcslashes — 反轉義addcslashes()函數轉義處理過的字元串
stripos — 查找並返回首個匹配項的位置,匹配不區分大小寫
stripslashes — 反轉義addslashes()函數轉義處理過的字元串
stristr — 通過比較返回一個字元串的部分,比較時不區分大小寫
strlen — 獲取一個字元串的編碼長度
strnatcasecmp — 使用自然排序法對字元串進行大小比較,不區分大小寫
strnatcmp — 使用自然排序法對字元串進行大小比較
strncasecmp — 對字元串的前N個字元進行大小比較,不區分大小寫
strncmp — 對字元串的前N個字元進行大小比較
strpbrk — 通過比較返回一個字元串的部分
strpos — 查找並返回首個匹配項的位置
strrchr — 通過從後往前比較返回一個字元串的.部分
strrev — 將字元串裡面的所有字母反向排列
strripos — 從後往前查找並返回首個匹配項的位置,匹配不區分大小寫
strrpos – 從後往前查找並返回首個匹配項的位置
strspn — 匹配並返回字元連續出現長度的值
strstr — 通過比較返回一個字元串的部分
strtok — 用指定的若干個字元來分割字元串
strtolower — 將字元串轉變為小寫
strtoupper –將字元串轉變為大寫
strtr — 對字元串比較替換
substr_compare — 對字元串進行截取後的比較
substr_count — 計算字元串中某字元段的出現次數
substr_replace — 對字元串中的部分字元進行替換
substr — 對字元串進行截取
trim — 去除字元串兩邊的空白或者指定的字元
ucfirst — 將所給字元串的第一個字母轉換為大寫
ucwords — 將所給字元串的每一個英文單詞的第一個字母變成大寫
vfprintf — 按照要求對數據進行返回,並直接寫入文檔流
vprintf — 按照要求對數據進行顯示
vsprintf — 按照要求對數據進行返回,但是不輸出
wordwrap — 按照一定的字元長度分割字元串
strtolower()函數把所有字元變成小寫,strtoupper()函數把所有字元變成大寫,ucfirst()函數將所給字元串的第一個字母轉換為大寫,ucwords()函數將所給字元串的每一個英文單詞的第一個字母變成大寫。ucfirst()只處理字元串的首個字元,ucwords()只處理每個單詞的首字母(以空格來界定是否是單詞,「today!Hi」、「today.Hi」 會被認為是一個單詞),對於其餘字母的大小寫狀態並不改變。 ;
php中編碼轉換問題
function uc2html($str) {
$ret = ‘ ‘;
for( $i=0; $i strlen($str)/2; $i++ ) {
$charcode = ord($str[$i*2])+256*ord($str[$i*2+1]);
$ret .= iconv( “utf-8 “, “gb2312 “,u2utf8($charcode));
}
return $ret;
}
function u2utf8($c) {
$str= ” “;
if ($c 0x80) {
$str.=$c;
} else if ($c 0x800) {
$str.=chr(0xC0 | $c 6);
$str.=chr(0x80 | $c 0x3F);
} else if ($c 0x10000) {
$str.=chr(0xE0 | $c 12);
$str.=chr(0x80 | $c 6 0x3F);
$str.=chr(0x80 | $c 0x3F);
} else if ($c 0x200000) {
$str.=chr(0xF0 | $c 18);
$str.=chr(0x80 | $c 12 0x3F);
$str.=chr(0x80 | $c 6 0x3F);
$str.=chr(0x80 | $c 0x3F);
}
return $str;
}
如果你不是smarty的話 試試這個 如果是smarty的話 用下面的方法
?php
/*
@Author: 蝸牛
@Blog:
@Note: 這個解決辦法是基於上面那個地址提到的方法,解決了中英文截取長度時出現亂碼的問題
*/
function smarty_modifier_truncate($string, $sublen = 80, $etc = ‘…’, $break_words = false, $middle = false)
{
$start=0;
$code=”UTF-8″;
if($code == ‘UTF-8’)
{
//如果有中文則減去中文的個數
$cncount=cncount($string);
if($cncount($sublen/2))
{
$sublen=ceil($sublen/2);
}
else
{
$sublen=$sublen-$cncount;
}
$pa = “/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|\xe0[\xa0-\xbf][\x80-\xbf]|[\xe1-\xef][\x80-\xbf][\x80-\xbf]|\xf0[\x90-\xbf][\x80-\xbf][\x80-\xbf]|[\xf1-\xf7][\x80-\xbf][\x80-\xbf][\x80-\xbf]/”;
preg_match_all($pa, $string, $t_string);
if(count($t_string[0]) – $start $sublen) return join(”, array_slice($t_string[0], $start, $sublen)).”…”;
return join(”, array_slice($t_string[0], $start, $sublen));
}
else
{
$start = $start*2;
$sublen = $sublen*2;
$strlen = strlen($string);
$tmpstr = ”;
for($i=0; $i$strlen; $i++)
{
if($i=$start $i($start+$sublen))
{
if(ord(substr($string, $i, 1))129)
{
$tmpstr.= substr($string, $i, 2);
}
else
{
$tmpstr.= substr($string, $i, 1);
}
}
if(ord(substr($string, $i, 1))129) $i++;
}
if(strlen($tmpstr)$strlen ) $tmpstr.= “…”;
return $tmpstr;
}
}
function cncount($str)
{
$len=strlen($str);
$cncount=0;
for($i=0;$i$len;$i++)
{
$temp_str=substr($str,$i,1);
if(ord($temp_str) 127)
{
$cncount++;
}
}
return ceil($cncount/3);
}
?
是可以的以上兩種方法 site:
PHP字元串轉數字
用convert()函數把欄位轉一下類型,然後再排序試試。
SELECT *
FROM `test`
ORDER BY convert( joke_sort, UNSIGNED ) DESC
LIMIT 0 , 30
如果只要一條記錄,直接limit 1完事。
怎樣在PHP中把16進位HEX數據轉換為2進位數據呢?
十六進位轉為二進位有兩種理解方法,第一是十六進位字元串轉二進位字元串,第二是十六進位數轉二進位數,下面分別介紹2種轉換方法:
1.hex2bin函數可以將十六進位字元串轉換為二進位字元串,詳細用法如下:
hex2bin — 轉換十六進位字元串為二進位字元串
string hex2bin(string $data)
轉換十六進位字元串為二進位字元串。
參數:
data:十六進位表示的數據
返回值:
返回給定數據的二進位表示 或者在失敗時返回 FALSE。
異常:
如果輸入的十六進位字元串是奇數長數或者無效的十六進位字元串將會拋出E_WARNING 級別的錯誤。
示例:
$hex = hex2bin(“6578616d706c65206865782064617461”);
echo $hex;//example hex data(其中16進位代表的是ascii碼)
2.base_convert是真正意義上的進位轉換函數
base_convert — 在任意進位之間轉換數字
string base_convert( string $number, int $frombase, int $tobase)
返回一字元串,包含 number以 tobase 進位的表示。number 本身的進位由frombase指定。frombase 和 tobase 都只能在2 和 36 之間(包括 2 和 36)。高於十進位的數字用字母 a-z 表示,例如a 表示 10,b 表示 11 以及 z 表示 35。
參數:
number:要轉換的數字
frombase:原始進位
tobase:轉換後的進位
示例:
$hexadecimal = ‘A37334’;
echo base_convert($hexadecimal, 16, 2);//101000110111001100110100
php 里 mb_convert_encoding()函數,
不過英文一般不會存在編碼問題,只有中文數據才會有這個問題。比如你用Zend Studio或Editplus寫程序時,用的是gbk編碼,如果數據需要入資料庫,而資料庫的編碼為utf8時,這時就要把數據進行編碼轉換,不然進到資料庫就會變成亂碼。
mb_convert_encoding的用法見官方:
做一個GBK To UTF-8
複製代碼代碼如下:
?php
header(“content-Type: text/html; charset=Utf-8”);
echo mb_convert_encoding(“你系我的友仔”, “UTF-8”, “GBK”);
?
再來個GB2312 To Big5
複製代碼代碼如下:
?php
header(“content-Type: text/html; charset=big5”);
echo mb_convert_encoding(“你是我的朋友”, “big5”, “GB2312”);
?
不過要使用上面的函數需要安裝但是需要先enable mbstring 擴展庫。
PHP中的另外一個函數iconv也是用來轉換字元串編碼的,與上函數功能相似。
下面還有一些詳細的例子:
iconv — Convert string to requested character encoding
(PHP 4 = 4.0.5, PHP 5)
mb_convert_encoding — Convert character encoding
(PHP 4 = 4.0.6, PHP 5)
用法:
string mb_convert_encoding ( string str, string to_encoding [, mixed from_encoding] )
需要先enable mbstring 擴展庫,在 php.ini里將; extension=php_mbstring.dll 前面的 ; 去掉
mb_convert_encoding 可以指定多種輸入編碼,它會根據內容自動識別,但是執行效率比iconv差太多;
string iconv ( string in_charset, string out_charset, string str )
注意:第二個參數,除了可以指定要轉化到的編碼以外,還可以增加兩個後綴://TRANSLIT 和 //IGNORE,其中 //TRANSLIT 會自動將不能直接轉化的字元變成一個或多個近似的字元,//IGNORE 會忽略掉不能轉化的字元,而默認效果是從第一個非法字元截斷。
Returns the converted string or FALSE on failure.
使用:
發現iconv在轉換字元」—」到gb2312時會出錯,如果沒有ignore參數,所有該字元後面的字元串都無法被保存。不管怎麼樣,這個」—」都無法轉換成功,無法輸出。 另外mb_convert_encoding沒有這個bug.
一般情況下用 iconv,只有當遇到無法確定原編碼是何種編碼,或者iconv轉化後無法正常顯示時才用mb_convert_encoding 函數.
from_encoding is specified by character code name before conversion. it can be array or string – comma separated enumerated list. If it is not specified, the internal encoding will be used.
/* Auto detect encoding from JIS, eucjp-win, sjis-win, then convert str to UCS-2LE */
$str = mb_convert_encoding($str, 「UCS-2LE」, 「JIS, eucjp-win, sjis-win」);
/* 「auto」 is expanded to 「ASCII,JIS,UTF-8,EUC-JP,SJIS」 */
$str = mb_convert_encoding($str, 「EUC-JP」, 「auto」);
例子:
複製代碼代碼如下:
$content = iconv(“GBK”, “UTF-8”, $content);
$content = mb_convert_encoding($content, “UTF-8″,”GBK”);
PHP中使用mb_convert_encoding轉碼的小陷阱
在php程序中使用mb_convert_encoding()方法進行字元編碼轉換大家都很熟悉了,平時也在大量的使用。而且在一般情況下該方法也表現的足夠好,值得表揚。但在一個項目中我們需要使用它進行UTF8到GBK的轉換,在轉換一些特殊字元時發現了一個不大不小的問題。具體表現為mb把在utf8可編碼的字元而在gbk中不可編碼的字元都轉成了\0x00\0x80,這樣就導致轉換後的gbk字元是有問題的。
在我們的意識中,在進行字元編碼轉換的過程中,如果遇到目標編碼不可表現的字元,轉碼程序應該做的是捨棄這種字元,這樣雖然丟失了部分數據,但不會導致轉碼的字元序列不可用。不清楚mb為什麼要使用上述方式而不是捨棄方式。
臨時的解決方式是對轉碼後的字元串序列進行過濾,過濾掉所有\x00\80的字元;又或者在轉義之前對utf8的字元串進行過濾,過濾掉ut8可表示而gbk不可表示的所有字元,從實現難度上來講,第一種過濾方式比較容易做到。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/271696.html