我似乎把自己弄糊涂了,无法修复循环,我期望生成一个数据集,它在我的excel表中右移和下移,但由于某种原因,每一个新行都会在第一行的末尾被截断,因此我的回溯错误,我试图读取上面的空单元格。我希望能有新的眼光来看待它,因为我后来的代码依赖于这个正确的输出,希望它能解决全球经济衰退,或者不会,但会让我成为一个快乐的人。:)
import datetime
import random
import numpy as np
import math
import sys
from openpyxl import Workbook
from openpyxl.cell import get_column_letter
from openpyxl import load_workbook
from tempfile import TemporaryFile
from random import normalvariate, expovariate, seed, gammavariate
from math import sqrt
from itertools import groupby
for week in CurrentWeek:
Global_counter = week
i = Global_counter
j = 52 + i
if Global_counter == 1:
for index in range(i,j,1):
PlanWeek = index
EC_D = 500.0
if EC_D <= 0:
EC_D = EC_D *(-1)
EC_PlanData.append(EC_D)
d = sheet1.cell(row = Global_counter, column = PlanWeek)
d2 = sheet2.cell(row = Global_counter, column = PlanWeek)
d.value = EC_D
d2.value = EC_D
else:
for index in range(i,j,1):
PlanWeek = index
DiffWeek = PlanWeek - Global_counter
Sigma = 1
mu = 0
FC_VZ = random.normalvariate(mu, Sigma)
if FC_VZ > 0:
FC_VZ = 1
FC_Error = FC_Error+RemainingFCError
fcerr = sheet5.cell(row = Global_counter, column = PlanWeek)
fcerr.value = FC_Error
Prev_Week = Global_counter - 1
ECDD1 = sheet1.cell(row=Prev_Week, column=PlanWeek).value
ECDD2 = sheet1.cell(row=Prev_Week, column=PlanWeek).value
EC_D = ECDD1 - (ECDD2*FC_Error)
FC_Error = 0
ECPD = sheet1.cell(row = Global_counter, column=PlanWeek)
ECPD.value = EC_D
FCAD = sheet6.cell(row = Global_counter, column=PlanWeek)
FCAD.value = FC_Error
IEFD = sheet2.cell(row = Global_counter, column=PlanWeek)
IEFD.value = EC_D
EC_D = 0
wb.save('RHF_Loop_test4py.xlsx')
我的回溯是:
^{pr2}$
我完全不明白你想计算什么,但这是引起上述异常的原因。在
首先,在第一个
for
循环中,在excel文件中取一行(第1行),并将该行中的列从第1列填充到第52列(索引从0开始):稍后,在第二个
for
循环中,当您读取值时,您将增加全局计数器,这样当抛出异常时,您将尝试读取第53周的值。在解决方案:而不是
你可以的
^{pr2}$您实际上创建了
DiffWeek
变量,但忘记使用它。在相关问题 更多 >
编程相关推荐