我正在尝试将数组元素顺序复制到excel。
这是代码:
array = ['A','B','C','D','E']
print len(array)
for i in range(1,len(array)):
sheet2.cell(i,1).value = array[i]
#print cell
#sheet2.cell(i,1).value = cell
wb2.save(path2)
预期:
应按顺序将A,B,C,D,E写入excel中的行
实际:
从B,C,D,E开始书写
我想念的是什么。很简单
答案 0 :(得分:0)
如果您对范围(1,len(array))中的i使用->: 您会错过数组的第一个元素,因为它以1.索引开头 python数组以0索引开头
像->那样使用它来表示范围(len(array))中的i:或范围(0,len(array))中的i:
答案 1 :(得分:0)
在python中,数组从零开始。这是正确的代码:
array = ['A','B','C','D','E']
print len(array)
for i in range(0,len(array)):
sheet2.cell(i+1,1).value = array[i]
#print cell
#sheet2.cell(i+1,1).value = cell
wb2.save(path2)
请注意,for循环从0开始。
答案 2 :(得分:0)
Python索引以0开头,excel索引显然以1开头。只需执行以下操作:
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
options = webdriver.ChromeOptions()
options.add_argument("start-maximized")
options.add_argument('disable-infobars')
driver = webdriver.Chrome(chrome_options=options, executable_path=r'C:\Utility\BrowserDrivers\chromedriver.exe')
driver.get("https://www.audiobooks.com/signup")
WebDriverWait(driver, 20).until(EC.frame_to_be_available_and_switch_to_it((By.XPATH,"//iframe[@id='braintree-hosted-field-number']")))
WebDriverWait(driver, 20).until(EC.element_to_be_clickable((By.XPATH, "//input[@class='number' and @id='credit-card-number']"))).send_keys("1234567890987654")