您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關php中trim不起作用如何解決的內容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
php trim不起作用的解決辦法:首先trim以相反的順序接受參數;然后從字符串的開頭和結尾為屏蔽字符設置字符串;最后將str_replace函數與空替換字符串一起使用即可。
具體問題:
為什么我的php trim()函數不起作用?
我正在嘗試使用trim從返回到$\u post數組的數據中刪除下劃線字符。我試著用
$post_Value= str_replace("_", " ", $key)
但文本似乎并不是作為一個字符串返回的。每個入口之間都斷了。然后我試著這樣修剪:
<?php $connection = mysqli_connect(DB_SERVER, DB_USER, DB_PASS, DB_NAME); // Test if connection succeeded if (mysqli_connect_errno()) { die("Database connection failed: " . mysqli_connect_error() . " (" . mysqli_connect_errno() . ")"); } if (isset($_POST)) { $str = ""; foreach($_POST as $key => $value) { $str = $str . $key . ","; } $post_Value = trim("_", $str); } $query = "UPDATE player_match SET categoryOption='$$post_Value' WHERE id=1"; ?>
當我使用trim函數時,什么都不會發生,它不會刪除_字符。我的最終目標是將逗號分隔的列表作為單個字符串放入數據庫。為什么我的trim()函數在這種情況下不起作用?
更新:在視圖頁資源中找到<br/>,因此我必須執行以下操作的組合:
$post_Value= str_replace("<br_/>", "", $str); $post_Value2= str_replace("_", " ", $post_Value); $post_Value3= rtrim($post_Value2,",submit,"); echo $post_Value3; $query="UPDATE player_match SET categoryOption='$post_Value3' WHERE id=1";
解決辦法:
首先,trim()以相反的順序接受參數:$str,然后$character_mask。所以你應該使用:$post_Value = trim($str, "_");
其次,trim()只從字符串的開頭和結尾為屏蔽字符設置字符串。如果字符串被非屏蔽字符包圍,則不會從字符串中刪除任何屏蔽字符。
實際上,您應該將str_replace()與空替換字符串一起使用(您嘗試了使用單個空格作為替換):
$post_Value= str_replace("_", "", $key)
如果您還想刪除<br>標記(在其典型的變體中),可以通過單個str_replace()調用執行此操作,如下所示:
$post_Value= str_replace(array("_", "<br>", "<br/>", "<br />"), "", $key)
感謝各位的閱讀!關于php中trim不起作用如何解決就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。