笨虫学爬虫 发表于 2020-5-19 21:14:28

如何同openpyxl按列向Excel中填充一个数列

自己使用ws.append(数列)来填充,在Excel中只是按行来填充,不能按列填充。请高手指导按列填充的方法,谢谢!

ouyunfu 发表于 2020-5-19 21:29:16

可能通过for循环实现,请参考以下代码
#encoding=utf-8
import xlrd
from xlwt import *
fileName="C:\\Users\\st\\Desktop\\test\\20170221131701.xlsx"
bk=xlrd.open_workbook(fileName)
shxrange=range(bk.nsheets)
sh=bk.sheet_by_name("Sheet1")
nrows=sh.nrows #获取行数
book = Workbook(encoding='utf-8')
sheet = book.add_sheet('Sheet1') #创建一个sheet
for i in range(1,nrows):
    row_data=sh.row_values(i)
    #获取第i行第3列数据
    #sh.cell_value(i,3)
    #---------写出文件到excel--------
    print "-----正在写入 "+str(i)+" 行"
    sheet.write(i,1, label = sh.cell_value(i,3)) #向第1行第1列写入获取到的值
    sheet.write(i,2, label = sh.cell_value(i,5)) #向第1行第2列写入获取到的值

笨虫学爬虫 发表于 2020-5-20 09:12:36

ouyunfu 发表于 2020-5-19 21:29
可能通过for循环实现,请参考以下代码

sheet.write(i,1, label = sh.cell_value(i,3)) #向第1行第1列写入获取到的值
return self._cell_values
IndexError: list index out of range

我试了以下,发现这些个问题,请帮忙看看。

jinlovelive 发表于 2020-5-20 10:08:37

把你自己写的代码发出来,还有相关文件

笨虫学爬虫 发表于 2020-5-20 10:19:38

jinlovelive 发表于 2020-5-20 10:08
把你自己写的代码发出来,还有相关文件

就是这个。
#encoding=utf-8
import xlrd
from xlwt import *
fileName="C:\\Users\\zhaop4\\Desktop\\Daily data base\\30_training\\17_Demo\\jiayu homework\\demo.xlsx"
bk=xlrd.open_workbook(fileName)
shxrange=range(bk.nsheets)
sh=bk.sheet_by_name("Sheet1")
nrows=sh.nrows #获取行数
book = Workbook(encoding='utf-8')
sheet = book.add_sheet('Sheet1') #创建一个sheet
for i in range(1,nrows):
    row_data=sh.row_values(i)
    #获取第i行第3列数据
    #sh.cell_value(i,3)
    #---------写出文件到excel--------
    print ("-----正在写入 "+str(i)+" 行")
    sheet.write(i,1, label = sh.cell_value(i,3)) #向第1行第1列写入获取到的值
    sheet.write(i,2, label = sh.cell_value(i,5)) #向第1行第2列写入获取到的值
页: [1]
查看完整版本: 如何同openpyxl按列向Excel中填充一个数列