Я ищу эффективный (возможно, нативную функцию, о которой я не знаю) способ прохождения символа строки за символом, если каждый последовательный символ соответствует критерию. Как только это не совпадает, весь шебанг может быть прекращен.
Вот начало цикла:
while (char == '-' or char == '+') for char in string:
Как эффективно закодировать эту строку?
Чтобы выполнить цикл последовательности и завершить цикл, если условие не выполнено, вы можете использовать break
:
for char in string:
if char not in ('-', '+'):
break
do_something_with(char)
Однако, если вы хотите просто собрать те элементы, которые соответствуют условию, вы можете искать itertools.takewhile
:
def find_sign_prefix(s):
sign_prefix = list(itertools.takewhile(lambda char: char in ('-', '+'), s))
return sign_prefix
print find_sign_prefix("--+-++---3.141592+-+")
# '--+-++---'
Или специально для проверки префикса строки вы можете использовать регулярное выражение:
def find_sign_prefix(s):
# `[+-]*` means "a '+' or '-' character, zero or more times";
# `re.search` only matches at the beginning of a string;
# group 0 is the matched substring
return re.search([+-]*, s).group(0)
Если вы просто считаете их, нет необходимости собирать их в список; вместо этого вы можете сделать num += sum(1 for _ in takewhile(lambda char: char in ('-', '+'), string))
.
Также, если вы заинтересованы в эффективности, есть несколько оптимизаций, например. если вы подготовите набор {'+', '-'}
как глобальную константу, проверки будут быстрее -- sum(1 for _ in takewhile(SIGN_CHARS.__contains__))
. Не имеет значения длина строки, важна только длина префикса, поскольку takewhile
останавливается, как только условие нарушается. Также возможно, что подход с регулярным выражением будет еще быстрее, опять же, если вы сохраните регулярное выражение как глобальную константу (PREFIX_PATTERN = re.compile("[+-]*")
)
Перебирайте каждый символ, используя цикл while, и прерывайте цикл, если возникает условие, которое вы ищете.
string = '....'
for i in range(len(string)-1):
char_i = string[i]
char_i_1 = string[i+1]
if not (char_i == '-' and char_i_1 == '+'):
break
Вы ищете проверку каждого символа на соответствие такому условию?
string = 'AB++-A+B-'
for char in string:
if char == '+' or char == '-':
# Do something
print(char)
Спасибо, воспользовалась
num += len(list(takewhile(lambda char: char in ('-', '+'), string)))
Как быстро берется? Эти строки иногда могут быть длинными