python循环x+;在列表中1次,直到数字y为止

python循环x+;在列表中1次,直到数字y为止,python,list,loops,random,iterate,Python,List,Loops,Random,Iterate,我想要的是numloopsx+1中的列表,直到生成y(循环停止),这是一个很大的数字 def loop_num(y): num = [] num.append([1]) num.append([2,3]) num.append([4,5,6]) num.append([7,8,9,10]) ... #stop append when y in the appended list #if y = 9, then `append [7,8]

我想要的是
num
loops
x+1
中的列表,直到生成
y
(循环停止),这是一个很大的数字

def loop_num(y):
    num = []
    num.append([1])
    num.append([2,3])
    num.append([4,5,6]) 
    num.append([7,8,9,10]) 
    ... #stop append when y in the appended list
    #if y = 9, then `append [7,8]` and `return num`
    return num


# something like[[1 item], [2items], [3items], ...]
# the number append to the list can be a random number or ascending integers. 

对不起,我不清楚你的问题是什么。但我假设你也做过类似的事情

x=[[1], [2,3], [4,5,6]]
b=[str(a)+' items' for a in [j for i in x for j in i]]
你要找的就是这个

c=max([j for i in x for j in i])
这样做

z=[]
z.append(str(c)+' items')
两个对象应能满足您的需要:

from itertools import count

def loop_num(y):
    counter, x = count(1), count(1)
    n = 0
    while n < y:
        num = []
        for i in range(next(x)):
            num.append(next(counter))
            if num[-1] == y:
                break
        yield num
        n = num[-1]

什么是x和y值?你能更清楚一点吗?x是整数如何循环并附加到列表中的>它附加项[[1次],[2次],[3次],…[x+1次]]y是停止循环的整数你的问题从列表中找到最大数对吗?如文所述,这个问题没有任何意义。不清楚那是什么,
num
。。。是输入吗?那么为什么不提供应该与该输入关联的输出呢。如果不是输入,那么。。。输入是什么?
>>> list(loop_num(100))
[[1],
 [2, 3],
 [4, 5, 6],
 [7, 8, 9, 10],
 [11, 12, 13, 14, 15],
 [16, 17, 18, 19, 20, 21],
 [22, 23, 24, 25, 26, 27, 28],
 [29, 30, 31, 32, 33, 34, 35, 36],
 [37, 38, 39, 40, 41, 42, 43, 44, 45],
 [46, 47, 48, 49, 50, 51, 52, 53, 54, 55],
 [56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66],
 [67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78],
 [79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91],
 [92, 93, 94, 95, 96, 97, 98, 99, 100]]
def loop_num(x):
    i=1
    cnt=0
    sum=0
    while sum<x:

        sum+=i
        cnt=cnt+1
        i=i+1

    num=[ [] for x in range(cnt)]

    count=0

    sz=1
    init=1
    while(count<cnt):
        cur=1
        while(cur<=sz):
            num[count].append(init)
            init=init+1
            cur=cur+1
        count=count+1
        sz=sz+1;
    return num
python -c 'import test; print test.loop_num(55)'