Respostas:
Use range
. No Python 2.x, ele retorna uma lista, então tudo que você precisa é:
>>> range(11, 17)
[11, 12, 13, 14, 15, 16]
No Python 3.x range
é um iterador. Então, você precisa convertê-lo em uma lista:
>>> list(range(11, 17))
[11, 12, 13, 14, 15, 16]
Nota : O segundo número é exclusivo. Então, aqui precisa ser 16+1
=17
EDITAR:
Para responder à pergunta sobre incrementar por 0.5
, a opção mais fácil provavelmente seria usar o numpy arange()
e .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
parâmetro, mas isso ainda é um int - não flutuante. Você não pode fazer isso exatamente na biblioteca padrão.
Você parece estar procurando 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]
Para incrementar em 0.5
vez de 1
, diga:
>>> 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
como uma variável.
list
é uma classe embutido, então seu uso como uma variável é um pouco desanimado
Tentar:
range(x1,x2+1)
Essa é uma lista no Python 2.xe se comporta principalmente como uma lista no Python 3.x. Se você estiver executando o Python 3 e precisar de uma lista que possa modificar, use:
list(range(x1,x2+1))
Se você está procurando uma função de faixa que funciona para o tipo float, aqui está um artigo muito bom .
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))
Resultado:
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]
Use a compreensão da lista em python. Como você também quer 16 na lista .. Use x2 + 1. A função Range exclui o limite mais alto na função.
lista = [x para x no intervalo (x1, x2 + 1)]
range()
sem necessidade de usar uma compreensão de lista
list(range(x1, x2+1))
.
Em python, você pode fazer isso muito avidamente
start=0
end=10
arr=list(range(start,end+1))
output: arr=[0,1,2,3,4,5,6,7,8,9,10]
ou você pode criar uma função recursiva que retorna uma matriz até um determinado número:
ar=[]
def diff(start,end):
if start==end:
d.append(end)
return ar
else:
ar.append(end)
return diff(start-1,end)
output: ar = [10,9,8,7,6,5,4,3,2,1,0]
A maneira mais elegante de fazer isso é usando a range
função; no entanto, se você deseja recriar essa lógica, pode fazer algo assim:
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)]
Isso produz a saída:
[10, 9, 8, 7, 6, 5, 4]
Conforme expresso anteriormente por @Jared, a melhor maneira é usar o range
ou, numpy.arrange
no entanto, acho o código interessante para ser compartilhado.
[x for x in range(10, 3, 1)]
- o primeiro argumento é o começo, o segundo o fim e o último o passo. ==> stop> start
Todas as respostas acima assumem que o intervalo é apenas de números positivos. Aqui está a solução para retornar a lista de números consecutivos em que os argumentos podem ser quaisquer (positivos ou negativos), com a possibilidade de definir o valor opcional da etapa (padrão = 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
Por exemplo, o comando padrão list(range(1,-3))
retorna a lista vazia []
, enquanto esta função retorna[-3,-2,-1,0,1]
Atualizado : agora a etapa pode ser negativa. Obrigado @ Michael pelo seu comentário.
i_min = -3, i_max = 1
any_number_range(i_max, i_min))
retornado. [-3,-2,-1,0,1]
Mas, builtin list(range(i_min, i_max + 1))
retornará os mesmos valores.
list(range(1,-3, -1))