1. 程式人生 > >PHP 陣列轉字串,與字串轉陣列

PHP 陣列轉字串,與字串轉陣列

沒有規律的陣列轉化為字串implode 使用一個字串將陣列變成字串

<br><?php
 
$array = array('lastname', 'email', 'phone');
$comma_separated = implode(",", $array);
 
echo $comma_separated; // lastname,email,phone
 
// Empty string when using an empty array:
var_dump(implode('hello', array())); // string(0) ""
 
?>

explode — 使用一個字串分割另一個字串,返回一個數組

<?php
// 示例 1
$pizza  = "piece1 piece2 piece3 piece4 piece5 piece6";
$pieces = explode(" ", $pizza);
echo $pieces[0]; // piece1
echo $pieces[1]; // piece2
 
// 示例 2
$data = "foo:*:1023:1000::/home/foo:/bin/sh";
list($user, $pass, $uid, $gid, $gecos, $home, $shell) = explode(":", $data);
echo $user; // foo
echo $pass; // *
 
?>

這裡如果字串沒有任何符號可以進行分割的話,就需要考慮別的方法了

str_split — 將字串轉換為陣列

<?php
 
$str = "Hello Friend";
 
$arr1 = str_split($str);
$arr2 = str_split($str, 3);
 
print_r($arr1);
print_r($arr2);
 
?>
輸出結果
Array
(
    [0] => H
    [1] => e
    [2] => l
    [3] => l
    [4] => o
    [5] =>
    [6] => F
    [7] => r
    [8] => i
    [9] => e
    [10] => n
    [11] => d
)
 
Array
(
    [0] => Hel
    [1] => lo
    [2] => Fri
    [3] => end
)

如果不相容的話,就只有考慮別的方法了,將字串逐位進行打斷,

這裡有一個將字串進行打斷的手動的方法,是原來為了寫日語半形的假名驗證的一個方法

這裡是一串對半形的假名的列舉

function kana_Perl($katakana){
         
    $katakana_array = array(
        1=>"ア",2=>"イ",3=>"ウ",4=>"エ",5=>"オ",
         
        6=>"カ",7=>"キ",8=>"ク",9=>"ケ",10=>"コ",
         
        11=>"サ",12=>"シ",13=>"ス",14=>"セ",15=>"ソ",
         
        16=>"タ",17=>"チ",18=>"ツ",19=>"テ",20=>"ト",
         
        21=>"ナ",22=>"ニ",23=>"ヌ",24=>"ネ",25=>"ノ",
         
        26=>"ハ",27=>"ヒ",28=>"フ",29=>"ヘ",30=>"ホ",
         
        31=>"マ",32=>"ミ",33=>"ム",34=>"メ",35=>"モ",
         
        36=>"ヤ",37=>"ユ",38=>"ヨ",
         
        39=>"ラ",40=>"リ",41=>"ル",42=>"レ",43=>"ロ",
         
        44=>"ワ",45=>"ヲ",46=>"ン",
     
        47=>"ァ",48=>"ィ",49=>"ゥ",50=>"ェ",51=>"ォ",
         
        52=>"ャ",53=>"ュ",54=>"ョ",55=>"ッ",56=>"、",
         
        57=>"。",58=>"ー",59=>"゙",60=>"゚"
        );
         
         $check_result   = array_search($katakana,$katakana_array);
          
         return $check_result;
         
    }

這是一段匹配的法則,注意這裡是i +=2,因為一個文字佔2位

function substr_cut($katakana){
    $i_end = 2;
    $check_sucess = "";
    for($i_start=0; $i_start < strlen($katakana); $i_start=$i_start+2){
         
        $str_cut = substr($katakana,$i_start,$i_end);
        echo '$str_cut='.$str_cut.'<br>';
        $check_sucess = kana_Perl($str_cut);
        if(!$check_sucess){
            break;
        }
         
 
    }
    return $check_sucess;
}

沒有規律的陣列轉化為字串

function substr_cut($katakana){
    $i_end = 1; //打斷位數長度,分清楚英文和中文
    $check_sucess = array();
    for($i_start=0; $i_start < strlen($katakana); $i_start=$i_start+1){       
        $str_cut = substr($katakana,$i_start,$i_end);
        $check_sucess[$i_start] = $str_cut;
        echo '$str_cut='.$str_cut.'<br>';
    }
    return $check_sucess;
}