在 Python 中将列表(List)转换为队列(Queue)

使用 collections.deque 类将列表转换为 Python 中的队列,例如 deq = deque(my_list)。 deque 类可以传递一个可迭代的对象,例如一个列表,并初始化一个新的 deque 对象。

from collections import deque

my_list = [1, 2, 3]

# ✅ convert list to queue
deq = deque(my_list)

print(deq)  # 👉️ deque([1, 2, 3])

deq.append(4)

print(deq)  # 👉️ deque([1, 2, 3, 4])

print(deq.pop())  # 👉️ 4

print(deq.popleft())  # 👉️ 1

collections.deque 类接受一个可迭代对象并初始化一个双端队列对象(一个双端队列)。

该类具有原子 append(),实现 popleft() 方法并支持索引和成员资格测试。

如果我们需要使用队列模块来创建队列,请使用 for 循环将列表转换为队列。

import queue

my_list = [1, 2, 3]

q = queue.Queue()

for item in my_list:
    q.put(item)

print(q.queue)  # 👉️ deque([1, 2, 3])

Queue.put 方法将一个项目放入队列中。

队列上的队列属性指向一个功能更全的双端队列对象。

只有在多线程环境中运行代码时,才应该使用 queue 模块。

以下是 deque 类实现的一些最常用的方法。

from collections import deque

my_list = [1, 2, 3]

deq = deque(my_list)


# 👇️ 在双端队列的右侧添加一个值
deq.append(4)

# 👇️ 在双端队列的左侧添加一个值
deq.appendleft(0)

# 👇️ 通过附加可迭代项中的项目来扩展双端队列的右侧
deq.extend([5, 6])

# 👇️ 从双端队列的右侧移除并返回一个元素
print(deq.pop())  # 👉️ 6

# 👇️ 从双端队列的左侧移除并返回一个元素
print(deq.popleft())  # 👉️ 0

print(deq)  # 👉️ deque([1, 2, 3, 4, 5])

deq.clear()

print(deq)  # 👉️ deque([])
免责声明:
1.本站所有内容由本站原创、网络转载、消息撰写、网友投稿等几部分组成。
2.本站原创文字内容若未经特别声明,则遵循协议CC3.0共享协议,转载请务必注明原文链接。
3.本站部分来源于网络转载的文章信息是出于传递更多信息之目的,不意味着赞同其观点。
4.本站所有源码与软件均为原作者提供,仅供学习和研究使用。
5.如您对本网站的相关版权有任何异议,或者认为侵犯了您的合法权益,请及时通知我们处理。
火焰兔 » 在 Python 中将列表(List)转换为队列(Queue)