Как удалить из строки ведущие и завершающие пробельные символы в Python?
Например:
" Hello " --> "Hello"
" Hello" --> "Hello"
"Hello " --> "Hello"
"Bob has a cat" --> "Bob has a cat"
Только один пробел или все последовательные пробелы? Если второе, то у строк уже есть метод .strip()
:
>>> ' Hello '.strip()
'Hello'
>>> ' Hello'.strip()
'Hello'
>>> 'Bob has a cat'.strip()
'Bob has a cat'
>>> ' Hello '.strip() # ALL consecutive spaces at both ends removed
'Hello'
Однако если вам нужно удалить только один пробел, вы можете сделать это с помощью метода:
def strip_one_space(s):
if s.endswith(" "): s = s[:-1]
if s.startswith(" "): s = s[1:]
return s
>>> strip_one_space(" Hello ")
' Hello'
Также обратите внимание, что str.strip()
удаляет и другие пробельные символы (например, табуляции и новые строки). Чтобы удалить только пробелы, можно указать символ, который нужно удалить, в качестве аргумента к strip
, т. е:
>>> " Hello\n".strip(" ")
'Hello\n'
Как указывалось выше ответы
myString.strip()
удаляет все начальные и конечные пробельные символы, такие как \N, \Р \Т \F, пробел.
Для большей гибкости использования следующие
mystring совсем.lstrip()
mystring совсем.rstrip()
mystring совсем.полосы('\П')
или mystring совсем.lstrip('\Н\Р')
или `mystring совсем.rstrip('\н\т') и так далее.Более подробная информация доступна в документации
полоса
не ограничивается пробельных символов либо:
# remove all leading/trailing commas, periods and hyphens
title = title.strip(',.-')
Это удалит все ведущие и завершающие пробелы в myString
:
myString.strip()
Я хотел убрать слишком много пробелов в строке (также В между строк, а не только в начале или конце). Я сделал это, потому что я Дон'т знаю, как сделать это иначе:
string = "Name : David Account: 1234 Another thing: something "
ready = False
while ready == False:
pos = string.find(" ")
if pos != -1:
string = string.replace(" "," ")
else:
ready = True
print(string)
Это заменяет двойные пробелы на один пробел, пока у вас нет двойных пробелов больше
Я не мог найти решение, что я искал так что я создал некоторые пользовательские функции. Вы можете попробовать их.
def cleansed(s: str):
""":param s: String to be cleansed"""
assert s is not (None or "")
# return trimmed(s.replace('"', '').replace("'", ""))
return trimmed(s)
def trimmed(s: str):
""":param s: String to be cleansed"""
assert s is not (None or "")
ss = trim_start_and_end(s).replace(' ', ' ')
while ' ' in ss:
ss = ss.replace(' ', ' ')
return ss
def trim_start_and_end(s: str):
""":param s: String to be cleansed"""
assert s is not (None or "")
return trim_start(trim_end(s))
def trim_start(s: str):
""":param s: String to be cleansed"""
assert s is not (None or "")
chars = []
for c in s:
if c is not ' ' or len(chars) > 0:
chars.append(c)
return "".join(chars).lower()
def trim_end(s: str):
""":param s: String to be cleansed"""
assert s is not (None or "")
chars = []
for c in reversed(s):
if c is not ' ' or len(chars) > 0:
chars.append(c)
return "".join(reversed(chars)).lower()
s1 = ' b Beer '
s2 = 'Beer b '
s3 = ' Beer b '
s4 = ' bread butter Beer b '
cdd = trim_start(s1)
cddd = trim_end(s2)
clean1 = cleansed(s3)
clean2 = cleansed(s4)
print("\nStr: {0} Len: {1} Cleansed: {2} Len: {3}".format(s1, len(s1), cdd, len(cdd)))
print("\nStr: {0} Len: {1} Cleansed: {2} Len: {3}".format(s2, len(s2), cddd, len(cddd)))
print("\nStr: {0} Len: {1} Cleansed: {2} Len: {3}".format(s3, len(s3), clean1, len(clean1)))
print("\nStr: {0} Len: {1} Cleansed: {2} Len: {3}".format(s4, len(s4), clean2, len(clean2)))
Если вы хотите обрезать заданное количество пробелов слева и справа, вы могли бы сделать это:
def remove_outer_spaces(text, num_of_leading, num_of_trailing):
text = list(text)
for i in range(num_of_leading):
if text[i] == " ":
text[i] = ""
else:
break
for i in range(1, num_of_trailing+1):
if text[-i] == " ":
text[-i] = ""
else:
break
return ''.join(text)
txt1 = " MY name is "
print(remove_outer_spaces(txt1, 1, 1)) # result is: " MY name is "
print(remove_outer_spaces(txt1, 2, 3)) # result is: " MY name is "
print(remove_outer_spaces(txt1, 6, 8)) # result is: "MY name is"