Ответы:
$newstr = substr_replace($oldstr, $str_to_insert, $pos, 0);
$str = substr($oldstr, 0, $pos) . $str_to_insert . substr($oldstr, $pos);
Используйте функцию stringInsert, а не функцию putinplace. Я использовал более позднюю функцию для анализа запроса MySQL. Хотя вывод выглядел хорошо, запрос привел к ошибке, которая заняла у меня некоторое время, чтобы отследить. Ниже приведена моя версия функции stringInsert, для которой требуется только один параметр.
function stringInsert($str,$insertstr,$pos)
{
$str = substr($str, 0, $pos) . $insertstr . substr($str, $pos);
return $str;
}
У меня есть одна моя старая функция для этого:
function putinplace($string=NULL, $put=NULL, $position=false)
{
$d1=$d2=$i=false;
$d=array(strlen($string), strlen($put));
if($position > $d[0]) $position=$d[0];
for($i=$d[0]; $i >= $position; $i--) $string[$i+$d[1]]=$string[$i];
for($i=0; $i<$d[1]; $i++) $string[$position+$i]=$put[$i];
return $string;
}
// Explanation
$string='My dog dont love postman'; // string
$put="'"; // put ' on position
$position=10; // number of characters (position)
print_r( putinplace($string, $put, $position) ); //RESULT: My dog don't love postman
Это небольшая мощная функция, которая выполняет свою работу без нареканий.
Это было мое простое решение: добавить текст в следующую строку после того, как было найдено ключевое слово.
$oldstring = "This is a test\n#FINDME#\nOther text and data.";
function insert ($string, $keyword, $body) {
return substr_replace($string, PHP_EOL . $body, strpos($string, $keyword) + strlen($keyword), 0);
}
echo insert($oldstring, "#FINDME#", "Insert this awesome string below findme!!!");
Вывод:
This is a test
#FINDME#
Insert this awesome string below findme!!!
Other text and data.
Просто хотел кое-что добавить: я нашел ответ Тима Купера очень полезным, я использовал его, чтобы создать метод, который принимает массив позиций и выполняет вставку для всех из них, вот так:
РЕДАКТИРОВАТЬ: похоже, моя старая функция предполагала, что$insertstr
был только 1 символ, и что массив был отсортирован. Это работает для произвольной длины символа.
function stringInsert($str, $pos, $insertstr) {
if (!is_array($pos)) {
$pos = array($pos);
} else {
asort($pos);
}
$insertionLength = strlen($insertstr);
$offset = 0;
foreach ($pos as $p) {
$str = substr($str, 0, $p + $offset) . $insertstr . substr($str, $p + $offset);
$offset += $insertionLength;
}
return $str;
}
Простой и еще один способ решить:
function stringInsert($str,$insertstr,$pos)
{
$count_str=strlen($str);
for($i=0;$i<$pos;$i++)
{
$new_str .= $str[$i];
}
$new_str .="$insertstr";
for($i=$pos;$i<$count_str;$i++)
{
$new_str .= $str[$i];
}
return $new_str;
}
function insSubstr($str, $sub, $posStart, $posEnd){
return mb_substr($str, 0, $posStart) . $sub . mb_substr($str, $posEnd + 1);
}
$posEnd
не требуется Вопрос был о вставке подстроки после указанной позиции.
Странные ответы здесь! Вы можете легко вставлять строки в другие строки с помощью sprintf [ссылка на документацию]. Функция очень мощная и может обрабатывать несколько элементов и других типов данных.
$color = 'green';
sprintf('I like %s apples.', $color);
дает вам строку
I like green apples.
'I like apples.'
в качестве переменной. Таким образом, мы должны вставить %s
сначала в строку, которые возвращаются к исходной задаче