更新gspread中超过26的单元格

问题描述 投票:0回答:1

我正在努力为我的工作自动化google工作表上的排册系统(我在书店工作,我正在学习编码作为一种爱好)..我创建了两个列表,一个带有时隙,另一个带有我的日子想要在电子表格中打印。

到目前为止,这是我的代码:

days = ["Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"]
daysIter = iter(days)
timeslots = ["8:00AM","8:30AM","9:00AM","9:30AM","10:00AM","10:30AM","11:00AM","11:30AM",
             "12:00PM","12:30PM","1:00PM","1:30PM","2:00PM","2:30PM","3:00PM","3:30PM","4:00PM","4:30PM",
             "5:00PM","5:30PM","6:00PM","6:30PM","7:00PM","7:30PM","8:00PM","8:30PM","9:00PM","9:30PM"]


timesIter = iter(timeslots)

daysonsheet = sheet.range("A2:A7")
timesonsheet = sheet.range("C1:AD1")

    


sheet.update_acell('A1',days[0])
for cell in daysonsheet:
    cell.value = next(daysIter)
    sheet.update_cells(daysonsheet)

sheet.update_acell('B1',timeslots[0])
for cell1 in timeslots:
    cell1.value = next(timesIter)
    sheet.update_cells(timesonsheet)
    
    
    
    

我可以更新daysonsheet,但是timesonsheet会抛出:

  File "/Users/*******/Rostering2", line 52, in <module>
    cell1.value = next(timesIter)

AttributeError: 'str' object has no attribute 'value'

据我所知,它们都是相同的,但for循环中的'cell'不是作为对象创建的,'cell1'是出于某种原因。

如果有人能够对此有所了解,那就太好了。

python gspread
1个回答
0
投票

代码中的timeslots是一个字符串列表,它没有.value属性。你应该循环遍历一个Cell对象列表,这是timeonsheet。另外,考虑在循环外移动sheet.update_cells调用以节省API调用。

for cell1 in timesonsheet:
    cell1.value = next(timesIter)
sheet.update_cells(timesonsheet)
© www.soinside.com 2019 - 2024. All rights reserved.