Przypuszczam 12345, że moje dane wejściowe w postaci liczb całkowitych chcę podzielić i umieścić w tablicy jako 1, 2, 3, 4, 5. Jak będę mógł to zrobić?
lub, jeśli nie chcesz używać rozumienia list lub chcesz użyć podstawy innej niż 10
from __future__ import division # for compatibility of // between Python 2 and 3defdigits(number, base=10):assert number >= 0if number == 0:
return [0]
l = []
while number > 0:
l.append(number % base)
number = number // base
return l
Jak widać, da to cyfry od prawej do lewej. Jeśli chcesz cyfry od lewej do prawej, musisz utworzyć z nich sekwencję, a następnie ją odwrócić:
reversed(tuple(digitize(x)))
Możesz również użyć tej funkcji do konwersji bazowej podczas dzielenia liczby całkowitej. Poniższy przykład dzieli liczbę szesnastkową na binarne półbajty jako krotki:
Chociaż list(map(int, str(x)))jest to podejście Pythonic, możesz sformułować logikę do wyprowadzania cyfr bez jakiejkolwiek konwersji typu:
from math import log10
defdigitize(x):
n = int(log10(x))
for i in range(n, -1, -1):
factor = 10**i
k = x // factor
yield k
x -= k * factor
res = list(digitize(5243))
[5, 2, 4, 3]
Jedną z zalet jest generator można karmić płynnie set, tuple, next, itp, bez jakiejkolwiek dodatkowej logiki.
list(map(int,str(12345)))
[int(i) for i in str(number)]
lub, jeśli nie chcesz używać rozumienia list lub chcesz użyć podstawy innej niż 10
from __future__ import division # for compatibility of // between Python 2 and 3 def digits(number, base=10): assert number >= 0 if number == 0: return [0] l = [] while number > 0: l.append(number % base) number = number // base return l
źródło
divmod
Wolałbym nie zamieniać liczby całkowitej w ciąg, więc oto funkcja, której używam do tego:
def digitize(n, base=10): if n == 0: yield 0 while n: n, d = divmod(n, base) yield d
Przykłady:
tuple(digitize(123456789)) == (9, 8, 7, 6, 5, 4, 3, 2, 1) tuple(digitize(0b1101110, 2)) == (0, 1, 1, 1, 0, 1, 1) tuple(digitize(0x123456789ABCDEF, 16)) == (15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1)
Jak widać, da to cyfry od prawej do lewej. Jeśli chcesz cyfry od lewej do prawej, musisz utworzyć z nich sekwencję, a następnie ją odwrócić:
Możesz również użyć tej funkcji do konwersji bazowej podczas dzielenia liczby całkowitej. Poniższy przykład dzieli liczbę szesnastkową na binarne półbajty jako krotki:
import itertools as it tuple(it.zip_longest(*[digitize(0x123456789ABCDEF, 2)]*4, fillvalue=0)) == ((1, 1, 1, 1), (0, 1, 1, 1), (1, 0, 1, 1), (0, 0, 1, 1), (1, 1, 0, 1), (0, 1, 0, 1), (1, 0, 0, 1), (0, 0, 0, 1), (1, 1, 1, 0), (0, 1, 1, 0), (1, 0, 1, 0), (0, 0, 1, 0), (1, 1, 0, 0), (0, 1, 0, 0), (1, 0, 0, 0))
Zwróć uwagę, że ta metoda nie obsługuje liczb dziesiętnych, ale można ją dostosować do.
źródło
jak @nd mówi, ale używając wbudowanej funkcji int do konwersji na inną bazę
>>> [ int(i,16) for i in '0123456789ABCDEF' ] [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15] >>> [int(i,2) for i in "100 010 110 111".split()] [4, 2, 6, 7]
Nie wiem, jaki jest ostateczny cel, ale zajrzyj również do modułu dziesiętnego Pythona, aby robić takie rzeczy
>>> Decimal('3.1415926535') + Decimal('2.7182818285') Decimal('5.85987')
źródło
Decimal
jest bezużyteczne dla tego pytaniaChociaż
list(map(int, str(x)))
jest to podejście Pythonic, możesz sformułować logikę do wyprowadzania cyfr bez jakiejkolwiek konwersji typu:from math import log10 def digitize(x): n = int(log10(x)) for i in range(n, -1, -1): factor = 10**i k = x // factor yield k x -= k * factor res = list(digitize(5243)) [5, 2, 4, 3]
Jedną z zalet jest generator można karmić płynnie
set
,tuple
,next
, itp, bez jakiejkolwiek dodatkowej logiki.źródło
Dzielenie pojedynczego numeru na cyfry (zgodnie z odpowiedzią wszystkich):
>>> [int(i) for i in str(12345)] [1, 2, 3, 4, 5]
Aby jednak uzyskać cyfry z listy liczb:
>>> [int(d) for d in ''.join(str(x) for x in [12, 34, 5])] [1, 2, 3, 4, 5]
Chciałbym więc wiedzieć, czy uda nam się to zrobić wydajniej.
źródło
Może
join
+split
:>>> a=12345 >>> list(map(int,' '.join(str(a)).split())) [1, 2, 3, 4, 5] >>> [int(i) for i in ' '.join(str(a)).split()] [1, 2, 3, 4, 5] >>>
str.join
+str.split
jest twoim przyjacielem, również używamymap
lub,list comprehension
aby uzyskać listę (podziel to, do czego dołączamy :-)).źródło
Inne rozwiązanie, które nie wymaga konwersji do / z ciągów:
from math import log10 def decompose(n): if n == 0: return [0] b = int(log10(n)) + 1 return [(n // (10 ** i)) % 10 for i in reversed(range(b))]
źródło
Ciągi są tak samo iterowalne jak tablice, więc po prostu przekonwertuj je na ciąg:
str(12345)
źródło
int
S niestr
Ingszgodnie z poprzednimi odpowiedziami, ciągi znaków są iterowalne, więc jeśli potrzebujesz listy cyfr, możesz ją dołączać pojedynczo, używając:
digits = [] digits += str(12345)
źródło