Php удалить пустые символы

ltrim

Удаляет пробелы (или другие символы) из начала строки.

Список параметров

С помощью параметра characters можно также указать удаляемые символы. Просто перечислите все символы, которые вы хотите удалить. Можно указать конструкцию .. для обозначения диапазона символов.

Возвращаемые значения

  • » » ( ASCII 32 ( 0x20 )), обычный пробел.
  • «\t» ( ASCII 9 ( 0x09 )), символ табуляции.
  • «\n» ( ASCII 10 ( 0x0A )), символ перевода строки.
  • «\r» ( ASCII 13 ( 0x0D )), символ возврата каретки.
  • «\0» ( ASCII 0 ( 0x00 )), NUL -байт.
  • «\v» ( ASCII 11 ( 0x0B )), вертикальная табуляция.

Примеры

Пример #1 Пример использования ltrim()

$text = «\t\tThese are a few words 🙂 . » ;
$binary = «\x09Example string\x0A» ;
$hello = «Hello World» ;
var_dump ( $text , $binary , $hello );

$trimmed = ltrim ( $text );
var_dump ( $trimmed );

$trimmed = ltrim ( $text , » \t.» );
var_dump ( $trimmed );

$trimmed = ltrim ( $hello , «Hdle» );
var_dump ( $trimmed );

// удаляем управляющие ASCII-символы с начала $binary
// (от 0 до 31 включительно)
$clean = ltrim ( $binary , «\x00..\x1F» );
var_dump ( $clean );

Результат выполнения данного примера:

string(32) " These are a few words :) . " string(16) " Example string " string(11) "Hello World" string(30) "These are a few words :) . " string(30) "These are a few words :) . " string(7) "o World" string(15) "Example string "

Смотрите также

  • trim() — Удаляет пробелы (или другие символы) из начала и конца строки
  • rtrim() — Удаляет пробелы (или другие символы) из конца строки

User Contributed Notes 8 notes

When using a $character_mask the trimming stops at the first character that is not on that mask.

So in the $string = «Hello world» example with $character_mask = «Hdle», ltrim($hello, $character_mask) goes like this:
1. Check H from «Hello world» => it is in the $character_mask, so remove it
2. Check e from «ello world» => it is in the $character_mask, so remove it
3. Check l from «llo world» => it is in the $character_mask, so remove it
4. Check l from «lo world» => it is in the $character_mask, so remove it
5. Check o from «o world» => it is NOT in the $character_mask, exit the function

Читайте также:  Переводчик на питоне api

Remaining string is «o world».

I hope it helps someone as I had a confusing moment with this function.

For those who use right-to-left languages such as Arabic, Hebrew, etc., it’s worth mentioning that ltrim() (which stands for left trim) & rtrim() (which stands for right trim) DO NOT work contextually. The nomenclature is rather semantically incorrect. So in an RTL script, ltrim() will trim text from the right direction (i.e. beginning of RTL strings), and rtrim() will trim text from the left direction (i.e. end of RTL strings).

Guys, if += 0 is producing wrong values sometimes, and preg_replace is cpu consuming, then just stick to the main function described on that page, and use:
$value = ltrim ( $value , ‘0’ );
?>
should be the fastest and most reliable.
I think all those comments can be misleading for begginers checking this page — it’s sort of using magic tricks to reinvent the wheel.

Suppose you have to ltrim zeroes from strings like «015», «002», etc. and convert them back to numbers, eg. using intval.

Suppose you must convert to number «000» too.

$trimmedString = ltrim(‘000’, ‘0’);

the value of $trimmedString would be NULL (and I think the docs should mention this).

Anyway, I initially thought I had to conditional check for this ‘000’, but I found that intval(NULL) returns 0 (this thing is not in the docs of intval but is in a comment)

The problem is that the character mask (_stw in your case) isn’t a literal string, but a character collection. So all characters within _stw are stripped. In your case this includes the w of weight also.

Источник

Удаление лишних пробелов в PHP.

Обрабатывая информацию, собирая ее из разных источников, например с сайта поставщика, мы часто сталкиваемся с тем, что нам надо ее привести в достойный вид, удалив лишние пробелы.

Читайте также:  Php post http request example

Удаление пробелов в начале или конце строки.

Стандартные функция trim( string $str [, string $character_mask = » \t\n\r\0\x0B» ]) удаляет все возможные пробелы в начале или в конце строки, так же эта функция может удалять те символы, которые вам не нужны, например точку или запятую:

Так же есть 2 функции, ltrim и rtrim, которые работают так же как и trim, за исключением того , что ltrim удаляет символы в начале строки, а rtrim в конце.

Удаление лишних пробелов в самом тексте.

Иногда нужно удалить лишние пробелы, а иногда и табы, в самом тексте, например: «Купив телефон сегодня вы получите самый лучший подарок». В этом тексте после каждого слова стоит более 1 пробела, Попробуем заменить лишние через регулярное выражение:

В данном случае \s говорит что надо заменить все пробелы, а + включая табы на 1 пробел. Если вы считаете, что регулярные выражения зло, то можно использовать:

$str = str_replace(» «, » «, $str); while( strpos($str,» «)!==false)

Удаление «не удаляемых» пробелов.

Возможно вы столкнулись с такой проблемой, что ни одно из средств перечисленных выше не удаляет пробелы. Для начала рассмотрите внимательно текст, желательно в исходном коде, потому что текст « Купив телефон сегодня вы получите самый лучший подарок» может оказаться таким: « Купив  телефон сегодня вы получите самый лучший подарок». Для начала надо заменить   и   просто на пробелы:

$str = str_replace('&', '&', $str); $str = str_replace(' ', ' ', $str);

А потом, применить один из способов, о котором я писал выше.

Хорошо, это мы сделали, но у нас остались лишние пробелы, которые не удаляются стандартными методами. Вероятнее всего это NO-BREAK SPACE, в таблице utf-8 символов он идет как c2 a0.

Для начала попробуйте перевести ваш текст в HEX:

echo bin2hex($str); echo substr_count($str, "\xc2\xa0");

и поищите там: c2a0, как видно на скриншоте, у меня аж 2 таких пробела

Удаление через регулярное выражение:

echo preg_replace('!\s++!u', ' ', $str);

Удаление без регулярного выражения:

$text = hex2bin(str_replace('c2a0', '20', bin2hex($str))); while( strpos($text,' ')!==false) < $text = str_replace(" ", " ", $text); >$text = trim($text);

переводим наш текс в HEX, заменяем NO-BREAK SPACE на обычный пробел, переводим обратно в обычный текст, после этого можно сделать замену пробелов и чистку.

Читайте также:  Массив всех символов java

Возможно у вас есть свой способ, может более практичный, как исправлять «не удаляемые» пробелы, то поделитесь в комментариях.

Источник

trim

Можно также задать список символов для удаления с помощью необязательного аргумента character_mask . Просто перечислите все символы, которые вы хотите удалить. Можно указать конструкцию .. для обозначения диапазона символов.

Возвращаемые значения

Примеры

Пример #1 Пример использования trim()

$text = «\t\tThese are a few words 🙂 . » ;
$binary = «\x09Example string\x0A» ;
$hello = «Hello World» ;
var_dump ( $text , $binary , $hello );

$trimmed = trim ( $text );
var_dump ( $trimmed );

$trimmed = trim ( $text , » \t.» );
var_dump ( $trimmed );

$trimmed = trim ( $hello , «Hdle» );
var_dump ( $trimmed );

$trimmed = trim ( $hello , ‘HdWr’ );
var_dump ( $trimmed );

// удаляем управляющие ASCII-символы с начала и конца $binary
// (от 0 до 31 включительно)
$clean = trim ( $binary , «\x00..\x1F» );
var_dump ( $clean );

Результат выполнения данного примера:

string(32) " These are a few words :) . " string(16) " Example string " string(11) "Hello World" string(28) "These are a few words :) . " string(24) "These are a few words :)" string(5) "o Wor" string(9) "ello Worl" string(14) "Example string"

Пример #2 Обрезание значений массива с помощью trim()

$fruit = array( ‘apple’ , ‘banana ‘ , ‘ cranberry ‘ );
var_dump ( $fruit );

array_walk ( $fruit , ‘trim_value’ );
var_dump ( $fruit );

Результат выполнения данного примера:

array(3) < [0]=>string(5) "apple" [1]=> string(7) "banana " [2]=> string(11) " cranberry " > array(3) < [0]=>string(5) "apple" [1]=> string(6) "banana" [2]=> string(9) "cranberry" >

Примечания

Замечание: Возможные трюки: удаление символов из середины строки

Так как trim() удаляет символы с начала и конца строки string , то удаление (или неудаление) символов из середины строки может ввести в недоумение. trim(‘abc’, ‘bad’) удалит как ‘a’, так и ‘b’, потому что удаление ‘a’ сдвинет ‘b’ к началу строки, что также позволит ее удалить. Вот почему это «работает», тогда как trim(‘abc’, ‘b’) очевидно нет.

Смотрите также

  • ltrim() — Удаляет пробелы (или другие символы) из начала строки
  • rtrim() — Удаляет пробелы (или другие символы) из конца строки
  • str_replace() — Заменяет все вхождения строки поиска на строку замены

Источник

Оцените статью