-1

我有一个固定大小为 10 的列表,我将以 2 秒的间隔放置我计算机的 CPU 百分比。我想要做的是,删除第一个元素,将每个元素移动到列表的前一个索引中,在列表的最后一个索引处记录第 11 个值

下面你可能会看到我的代码。我做了一些调试,但我现在很困惑。我怎样才能解决这个问题?

__author__ = 'tim'
#-*- coding: utf-8 -*-
import psutil, os, time

def getCpuRate():
   myList = [None]*10
   myString=" "
   myString2 = " "
   i = 0
   j = 0

   while True:
      if myList[9] is None:
         myList[i] = psutil.cpu_percent(interval=2)
         myString = myString + (str(myList[i]) + " ")
         i = i+1
         print i , myString
         #time.sleep(3)
      else:
         while i>0:
            myList[j] = myList[j+1]
            #print myList[j+1] , myList[j]
            for k in range(len(myList)):
               myString2 = myString + (str(myList[k]) + "")
            print i , j , myString2
            j = j+1
            i = i-1
            if j >= 9:
               myList[j] = psutil.cpu_percent(interval=2)
               print i , j , myString2
               j -= 1


print "a"
getCpuRate()
'''
mySecondList = getCpuRate()
for x in range(len(mySecondList)):
   print mySecondList[x]
'''
print "b"
4

2 回答 2

0

您可以使用deque文档链接)而不是使用列表,这是针对您想要的操作类型优化的列表。

import collections
q = collections.deque()

# add element at the end:
q.append('cpu percentage here')
# add element at the beginning:
q.appendleft('cpu percentage here')

# remove first element:
q.popleft()
# remove last element:
q.pop()

然后,您的循环变得更加简单:

import psutil
import collections

def getCpuRate():
    q = collections.deque(maxlen=10)
    while True:
        q.appendleft(psutil.cpu_percent(interval=2))
        print(q)

请注意我的排序,以便我们在开头插入新值并在末尾删除旧值。这样,新值在打印时首先出现q。如果您不希望这样,您可以逐个appendleft更改。appendpoppopleft

于 2015-02-13T09:59:57.967 回答
0

你为什么不使用双端队列

只需填写 10 个虚拟值,然后使用appendand pop。所以一切都向左移动。或者您指定maxlen=10双端队列的(最大长度)并且只使用append.

于 2015-02-13T09:51:42.037 回答