我有一个输入字符串:
$str = ':this is a applepie :) ';
我怎么能删除第一个发生:用PHP?
期望输出:这是一个苹果馅饼:)
我有一个输入字符串:
$str = ':this is a applepie :) ';
我怎么能删除第一个发生:用PHP?
期望输出:这是一个苹果馅饼:)
当前回答
substr()函数可能会帮助你:
$str = substr($str, 1);
字符串从0开始索引,该函数的第二个参数接受cutstart。所以把它设为1,第一个char就没有了。
其他回答
使用mb_substr函数
mb_substr("我abc", 1);
要移除字符串开头的每个:,你可以使用ltrim:
$str = '::f:o:';
$str = ltrim($str, ':');
var_dump($str); //=> 'f:o:'
使用字符串的子串:
$str = substr($str, 1); // this is a applepie :)
修剪数组中从字符串开头和结尾开始出现的每个单词+空格和根据正常trim()可选的额外单个字符
<?php
function trim_words($what, $words, $char_list = '') {
if(!is_array($words)) return false;
$char_list .= " \t\n\r\0\x0B"; // default trim chars
$pattern = "(".implode("|", array_map('preg_quote', $words)).")\b";
$str = trim(preg_replace('~'.$pattern.'$~i', '', preg_replace('~^'.$pattern.'~i', '', trim($what, $char_list))), $char_list);
return $str;
}
// for example:
$trim_list = array('AND', 'OR');
$what = ' OR x = 1 AND b = 2 AND ';
print_r(trim_words($what, $trim_list)); // => "x = 1 AND b = 2"
$what = ' ORDER BY x DESC, b ASC, ';
print_r(trim_words($what, $trim_list, ',')); // => "ORDER BY x DESC, b ASC"
?>
更新
经过进一步的测试,我不建议再使用它。当我在MySQL查询中使用更新的字符串时,它导致了一个问题,并更改为substr解决了这个问题。我想过删除这个答案,但评论表明它以某种方式更快,所以有人可能会用到它。您可能会发现修改更新的字符串可以解决字符串长度问题。
有时候你不需要一个函数:
$str[0] = '';
例如:
$str = 'AHello';
$str[0] = '';
echo $str; // 'Hello'
此方法修改现有字符串,而不是创建另一个字符串。