Dzielenie liczby całkowitej w Pythonie?

87

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ć?

Chłop
źródło

Odpowiedzi:

138
>>> [int(i) for i in str(12345)]

[1, 2, 3, 4, 5]
luc
źródło
91

zwraca tablicę jako ciąg

>>> list(str(12345))
['1', '2', '3', '4', '5']

zwraca tablicę jako liczbę całkowitą

>>> map(int,str(12345))
[1, 2, 3, 4, 5]
TY
źródło
24
W Pythonie3 byłoby tolist(map(int,str(12345)))
Serge Stroobandt
10
[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
nd.
źródło
Dobry telefon, właśnie to miałem napisać :)
Russell
@ i możesz umieścić podstawę liczby wewnątrz int, jak int (i, 2) dla binarnego, zobacz mój post
fabrizioM
To jest dobra odpowiedź, ale divmod
przydałaby się
6

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ć:

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:

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.

Will Da Silva
źródło
3

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')
fabrizioM
źródło
Decimaljest bezużyteczne dla tego pytania
jamylak
1

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

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.

jpp
źródło
0

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.

Nabeel Ahmed
źródło
0

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.splitjest twoim przyjacielem, również używamy maplub, list comprehensionaby uzyskać listę (podziel to, do czego dołączamy :-)).

U10-Forward
źródło
0

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))]
Alexandre V.
źródło
-2

Ciągi są tak samo iterowalne jak tablice, więc po prostu przekonwertuj je na ciąg:

str(12345)
rozwijać
źródło
PO chce intS nie strIngs
jamylak
-2

zgodnie 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)
blz
źródło
Nie widzę żadnych błędów. Jedynym problemem jest to, że wynikiem jest lista ciągów, a nie lista int.
Paul Rooney,