Comparaison rapide des timings en réponse au post de Abbafei :
import timeit
def func1():
phrase = 'Lucky Dog'
return any(i in 'LD' for i in phrase)
def func2():
phrase = 'Lucky Dog'
if ('L' in phrase) or ('D' in phrase):
return True
else:
return False
if __name__ == '__main__':
func1_time = timeit.timeit(func1, number=100000)
func2_time = timeit.timeit(func2, number=100000)
print('Func1 Time: {0}\nFunc2 Time: {1}'.format(func1_time, func2_time))
Sortie :
Func1 Time: 0.0737484362111
Func2 Time: 0.0125144964371
Le code est donc plus compact avec n'importe lequel, mais plus rapide avec le conditionnel.
EDIT : TL;DR -- Pour les longues chaînes de caractères, si-alors est toujours beaucoup plus rapide que n'importe quel autre !
J'ai décidé de comparer le timing d'une longue chaîne aléatoire en me basant sur certains des points valables soulevés dans les commentaires :
# Tested in Python 2.7.14
import timeit
from string import ascii_letters
from random import choice
def create_random_string(length=1000):
random_list = [choice(ascii_letters) for x in range(length)]
return ''.join(random_list)
def function_using_any(phrase):
return any(i in 'LD' for i in phrase)
def function_using_if_then(phrase):
if ('L' in phrase) or ('D' in phrase):
return True
else:
return False
if __name__ == '__main__':
random_string = create_random_string(length=2000)
func1_time = timeit.timeit(stmt="function_using_any(random_string)",
setup="from __main__ import function_using_any, random_string",
number=200000)
func2_time = timeit.timeit(stmt="function_using_if_then(random_string)",
setup="from __main__ import function_using_if_then, random_string",
number=200000)
print('Time for function using any: {0}\nTime for function using if-then: {1}'.format(func1_time, func2_time))
Sortie :
Time for function using any: 0.1342546
Time for function using if-then: 0.0201827
If-then est presque un ordre de grandeur plus rapide que n'importe quel autre !
1 votes
Cela signifie-t-il que chaque caractère est censé être l'un d'entre eux, ou suffit-il qu'un (ou tous) de ces caractères soit présent dans la chaîne ? Doivent-ils être dans un certain ordre (par exemple : $2,00) pour que la chaîne soit valide ?
3 votes
C'est une approche différente,
not set(p).isdisjoint(set("0123456789$,"))
dondep
est la chaîne à tester.0 votes
Cela répond-il à votre question ? Python dispose-t-il d'une méthode de sous-chaîne de caractères "contenant" ?