Odpowiedzi:
Zastosowanie range
. W Python 2.x zwraca listę, więc wszystko czego potrzebujesz to:
>>> range(11, 17)
[11, 12, 13, 14, 15, 16]
W Pythonie 3.x range
jest iteratorem. Musisz przekonwertować go na listę:
>>> list(range(11, 17))
[11, 12, 13, 14, 15, 16]
Uwaga : Drugi numer jest wyłączny. Więc tutaj musi być 16+1
=17
EDYTOWAĆ:
Aby odpowiedzieć na pytanie o zwiększenie o 0.5
, najłatwiejszą opcją byłoby prawdopodobnie użycie numpy arange()
i .tolist()
:
>>> import numpy as np
>>> np.arange(11, 17, 0.5).tolist()
[11.0, 11.5, 12.0, 12.5, 13.0, 13.5,
14.0, 14.5, 15.0, 15.5, 16.0, 16.5]
step
parametru, ale wciąż jest to int - not float. Nie możesz tego zrobić dokładnie w standardowej bibliotece lib.
Wygląda na to, że szukasz range()
:
>>> x1=11
>>> x2=16
>>> range(x1, x2+1)
[11, 12, 13, 14, 15, 16]
>>> list1 = range(x1, x2+1)
>>> list1
[11, 12, 13, 14, 15, 16]
Aby zwiększyć o, 0.5
zamiast 1
, powiedz:
>>> list2 = [x*0.5 for x in range(2*x1, 2*x2+1)]
>>> list2
[11.0, 11.5, 12.0, 12.5, 13.0, 13.5, 14.0, 14.5, 15.0, 15.5, 16.0]
list
jako zmiennej.
list
jest wbudowana klasa, więc korzystanie z niej jako zmiennej jest nieco odradzane
Próbować:
range(x1,x2+1)
To jest lista w Pythonie 2.x i zachowuje się jak lista w Pythonie 3.x. Jeśli używasz Python 3 i potrzebujesz listy, którą możesz zmodyfikować, użyj:
list(range(x1,x2+1))
Jeśli szukasz funkcji podobnej do zakresu, która działa dla typu float, to jest to bardzo dobry artykuł .
def frange(start, stop, step=1.0):
''' "range()" like function which accept float type'''
i = start
while i < stop:
yield i
i += step
# Generate one element at a time.
# Preferred when you don't need all generated elements at the same time.
# This will save memory.
for i in frange(1.0, 2.0, 0.5):
print i # Use generated element.
# Generate all elements at once.
# Preferred when generated list ought to be small.
print list(frange(1.0, 10.0, 0.5))
Wynik:
1.0
1.5
[1.0, 1.5, 2.0, 2.5, 3.0, 3.5, 4.0, 4.5, 5.0, 5.5, 6.0, 6.5, 7.0, 7.5, 8.0, 8.5, 9.0, 9.5]
Używaj rozumienia listy w Pythonie. Ponieważ chcesz też 16 na liście .. Użyj x2 + 1. Funkcja zakresu wyklucza górną granicę funkcji.
list = [x dla xw zakresie (x1, x2 + 1)]
range()
nie potrzebujesz, użyj rozumienia listy
list(range(x1, x2+1))
.
W Pythonie możesz to zrobić bardzo łatwo
start=0
end=10
arr=list(range(start,end+1))
output: arr=[0,1,2,3,4,5,6,7,8,9,10]
lub możesz utworzyć funkcję rekurencyjną, która zwraca tablicę do podanej liczby:
ar=[]
def diff(start,end):
if start==end:
d.append(end)
return ar
else:
ar.append(end)
return diff(start-1,end)
wynik: ar = [10,9,8,7,6,5,4,3,2,1,0]
Najbardziej eleganckim sposobem na to jest użycie tej range
funkcji, jednak jeśli chcesz odtworzyć tę logikę, możesz zrobić coś takiego:
def custom_range(*args):
s = slice(*args)
start, stop, step = s.start, s.stop, s.step
if 0 == step:
raise ValueError("range() arg 3 must not be zero")
i = start
while i < stop if step > 0 else i > stop:
yield i
i += step
>>> [x for x in custom_range(10, 3, -1)]
To daje wynik:
[10, 9, 8, 7, 6, 5, 4]
Wyrażone wcześniej przez @Jared, najlepszym sposobem jest użycie range
lub numpy.arrange
jednak znajdę interesującą kod do podziału.
[x for x in range(10, 3, 1)]
samej - pierwszy argument to początek, drugi koniec i ostatni krok. ==> stop> start
Każda powyższa odpowiedź zakłada, że zakres ma wyłącznie liczby dodatnie. Oto rozwiązanie, aby zwrócić listę kolejnych liczb, w których argumentami mogą być dowolne (dodatnie lub ujemne), z możliwością ustawienia opcjonalnej wartości kroku (domyślnie = 1).
def any_number_range(a,b,s=1):
""" Generate consecutive values list between two numbers with optional step (default=1)."""
if (a == b):
return a
else:
mx = max(a,b)
mn = min(a,b)
result = []
# inclusive upper limit. If not needed, delete '+1' in the line below
while(mn < mx + 1):
# if step is positive we go from min to max
if s > 0:
result.append(mn)
mn += s
# if step is negative we go from max to min
if s < 0:
result.append(mx)
mx += s
return result
Na przykład standardowe polecenie list(range(1,-3))
zwraca pustą listę []
, a funkcja ta powróci[-3,-2,-1,0,1]
Zaktualizowano : teraz krok może być ujemny. Dzięki @Michael za komentarz.
i_min = -3, i_max = 1
any_number_range(i_max, i_min))
zwraca, [-3,-2,-1,0,1]
ale wbudowane list(range(i_min, i_max + 1))
zwróci te same wartości.
list(range(1,-3, -1))