首頁 >後端開發 >php教程 >php單引號和雙引號用法

php單引號和雙引號用法

angryTom
angryTom原創
2019-08-22 09:47:139822瀏覽

php單引號和雙引號用法

  看好多程式碼有時候用單引號或雙引號實現包含字串的內容,其實簡單概括下就是雙引號中的變數可以解析,單引號就是絕對的字串。下面就為大家詳細介紹一下。

推薦教學:PHP影片教學

1、定義字串

  在PHP中,字串的定義可以使用單引號,也可以使用雙引號。但必須使用同一種單或雙引號來定義字串,如:‘Hello"和「He​​llo'為非法的字串定義。   

  定義字串時,只有一種引號被視為定義符,即單引號或雙引號。於是,如果一個字串由雙引號開始,那麼只有雙引號被分析器解析。這樣,你就可以在雙引號串中包含任何其他字符,甚至單引號。下面的引號字串都是合法的:

$s = "I am a 'single quote string' inside a double quote string"; 
$s = 'I am a "double quote string" inside a single quote string'; 
$s = "I am a 'single quote string' inside a double quote string"; 
$s = 'I am a "double quote string" inside a single quote string';   

  而串 "Why doesn't "this" work?" 則會被分成三段。如果在這個字串中想要表示出雙引號,則可以使用轉義符號"\"(反斜線),變成 "Why doesn't \"this\" work?" 即可。

2、字串變數中的單、雙引號

#PHP允許我們在雙引號串中直接包含字串變量,我們可以發現下面的兩個字串的處理結果是相同的。 

$full_name = $first_name . ' ' . $last_name; 
$full_name = "$first_name $last_name";  

  單引號串和雙引號串在PHP中的處理是不相同的。雙引號字串中的內容可以被解釋而且替換,而單引號字串中的內容總被認為是普通字元。例如: 

$foo = 2; 
echo "foo is $foo"; // 打印结果: foo is 2 
echo 'foo is $foo'; // 打印结果: foo is $foo 
echo "foo is $foo\n"; // 打印结果: foo is 2 (同时换行) 
echo 'foo is $foo\n'; // 打印结果: foo is $foo\n 
$foo = 2; 
echo "foo is $foo"; // 打印结果: foo is 2 
echo 'foo is $foo'; // 打印结果: foo is $foo 
echo "foo is $foo\n"; // 打印结果: foo is 2 (同时换行) 
echo 'foo is $foo\n'; // 打印结果: foo is $foo\n   

  正如你所看到的,在單引號串中甚至反斜杠也失去了他的擴展含義(除了插入反斜杠\\和插入單引號\')。所以,當你想在字符串中進行變數代換和包 含\n(換行符)等轉義序列時,你應該使用雙引號。單引號字串可以用在其他任何地方,腳本中使用單引號串處理速度會更快些,因為PHP語法分析器對單引號串的處理方式比較單純,而雙引號的處理由於串內部也需要解析,因此更複雜些,所以處理速度略慢。

  在字串中引用複雜的變數組合時,可能會產生一些問題,以下的程式碼會正常運作: 

echo "value = $foo"; 
echo "value = $a[$i]"; 
echo "value = $foo"; 
echo "value = $a[$i]";   

而下面的程式碼卻不能得到我們希望的結果: 

echo "value = $a[$i][$j]"; //我们希望打印二维数组$a的某个元素。   

為避免這些字符串使用中的潛在問題,我們通常把複雜的變數從字符串中分離開來,就像這樣:

echo 'value = ' . $a[$i][$j];//字符串的连接用点(.)

還有一種辦法是將複雜變數用花括號括起來,語法分析器就能正確辨認了: 

echo "value = {$a[$i][$j]}" //打印二维数组$a的某个元素   

# 3、在SQL語句中

  這是會經常遇到的問題,在插入資料庫的SQL語句是採用單引號來定義字串,如果要將一個含有單引號的字串插入資料庫,這個SQL語句就會出錯。

如:

$sql="insert into userinfo (username,password) Values('O'Kefee','123456')"  

  此時,處理的方法之一是在SQL語句中加入轉義符反斜線, 

即:…Values ('O\'Kefee',……    

  當然也可以使用函數addslashes(),函數的功能就是加入轉義符, 

即:

$s = addslashes("O'Kefee") ……Values('".$s."',……   

  還有一種方法是設定php.ini中的magic-quotes選項,打開該選項,則透過表單提交的資訊中如果有單引號是,將會自動加上如轉義符。因此不用使用其他函數了。

  補充: 這就要從雙引號和單引號的作用講起: 雙引號裡面的字段會經過編譯器解釋然後再當作HTML代碼輸出,但是單引號裡面的不需要解釋,直接輸出。 

例如: 

$abc='I love u'; 
echo $abc //结果是:I love u 
echo '$abc' //结果是:$abc 
echo "$abc" //结果是:I love u

  所以在對資料庫裡面的SQL語句賦值的時候也要用在雙引號裡面SQL="select a,b,c from .. ." 但是SQL語句中會有單引號把字段名引出來 

例如:

select * from table where user='abc';

  這裡的SQL語句可以直接寫成SQL="select * from table where user= 'abc'" 

  但是如果像下面

$user='abc'; 
SQL1="select * from table where user=' ".$user." ' ";对比一下 
SQL2="select * from table where user=' abc ' "

  我把單引號和雙引號之間多加了點空格,希望你能看的清楚一點。 

#  也就是把'abc' 替換為'".$user."'都是在一個單引號裡面的。只是把整個SQL字串分割了。 SQL1可以分解為以下3個部分 

################# 1:"select * from table where user=' " ######  2:$user ######  3:" ' " ######字串之間用. 來連接,這樣能明白了吧。 ####

以上是php單引號和雙引號用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn