A veces, mientras trabajamos con datos, podemos tener un problema en el que necesitamos verificar las ocurrencias de registros que ocurren en momentos similares. Esto tiene aplicación en el dominio de desarrollo web. Analicemos ciertas formas en que se puede realizar esta tarea.
Método #1: Usar map() + Counter()
+ ordenado
La combinación de las funcionalidades anteriores se puede utilizar para realizar esta tarea. En esto, antes de enviar datos a Counter()
, para contar ocurrencias, ordenamos los datos para hacer que todas las tuplas desordenadas se cuenten como una sola.
# Python3 code to demonstrate working of # Record Similar tuple occurrences # Using Counter() + map() + sorted from collections import Counter # initialize list test_list = [(3, 1), (1, 3), (2, 5), (5, 2), (6, 3)] # printing original list print("The original list is : " + str(test_list)) # Record Similar tuple occurrences # Using Counter() + map() + sorted res = dict(Counter(tuple(ele) for ele in map(sorted, test_list))) # printing result print("The frequency of like tuples : " + str(res))
The original list is : [(3, 1), (1, 3), (2, 5), (5, 2), (6, 3)] The frequency of like tuples : {(2, 5): 2, (1, 3): 2, (3, 6): 1}
Método #2: Usarfrozenset() + Counter()
La combinación de las funciones anteriores se puede utilizar para realizar esta tarea en particular. En este, la tarea realizada por sorted and map()
es realizada por el frozenset()
que ordena internamente las tuplas.
# Python3 code to demonstrate working of # Record Similar tuple occurrences # Using frozenset() + Counter() from collections import Counter # initialize list test_list = [(3, 1), (1, 3), (2, 5), (5, 2), (6, 3)] # printing original list print("The original list is : " + str(test_list)) # Record Similar tuple occurrences # Using frozenset() + Counter() res = dict(Counter(tuple(frozenset(ele)) for ele in test_list)) # printing result print("The frequency of like tuples : " + str(res))
The original list is : [(3, 1), (1, 3), (2, 5), (5, 2), (6, 3)] The frequency of like tuples : {(2, 5): 2, (1, 3): 2, (3, 6): 1}
Publicación traducida automáticamente
Artículo escrito por manjeet_04 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA