鱼C论坛

 找回密码
 立即注册
查看: 1470|回复: 4

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

[复制链接]
发表于 2020-5-19 21:14:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
自己使用ws.append(数列)来填充,在Excel中只是按行来填充,不能按列填充。请高手指导按列填充的方法,谢谢!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-5-19 21:29:16 | 显示全部楼层
可能通过for循环实现,请参考以下代码
  1. #encoding=utf-8
  2. import xlrd
  3. from xlwt import *
  4. fileName="C:\\Users\\st\\Desktop\\test\\20170221131701.xlsx"
  5. bk=xlrd.open_workbook(fileName)
  6. shxrange=range(bk.nsheets)
  7. sh=bk.sheet_by_name("Sheet1")
  8. nrows=sh.nrows #获取行数
  9. book = Workbook(encoding='utf-8')
  10. sheet = book.add_sheet('Sheet1') #创建一个sheet
  11. for i in range(1,nrows):
  12.     row_data=sh.row_values(i)
  13.     #获取第i行第3列数据
  14.     #sh.cell_value(i,3)
  15.     #---------写出文件到excel--------
  16.     print "-----正在写入 "+str(i)+" 行"
  17.     sheet.write(i,1, label = sh.cell_value(i,3)) #向第1行第1列写入获取到的值
  18.     sheet.write(i,2, label = sh.cell_value(i,5)) #向第1行第2列写入获取到的值
复制代码

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 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[rowx][colx]
IndexError: list index out of range

我试了以下,发现这些个问题,请帮忙看看。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-20 10:08:37 | 显示全部楼层
把你自己写的代码发出来,还有相关文件
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-20 10:19:38 | 显示全部楼层
jinlovelive 发表于 2020-5-20 10:08
把你自己写的代码发出来,还有相关文件

就是这个。
  1. #encoding=utf-8
  2. import xlrd
  3. from xlwt import *
  4. fileName="C:\\Users\\zhaop4\\Desktop\\Daily data base\\30_training\\17_Demo\\jiayu homework\\demo.xlsx"
  5. bk=xlrd.open_workbook(fileName)
  6. shxrange=range(bk.nsheets)
  7. sh=bk.sheet_by_name("Sheet1")
  8. nrows=sh.nrows #获取行数
  9. book = Workbook(encoding='utf-8')
  10. sheet = book.add_sheet('Sheet1') #创建一个sheet
  11. for i in range(1,nrows):
  12.     row_data=sh.row_values(i)
  13.     #获取第i行第3列数据
  14.     #sh.cell_value(i,3)
  15.     #---------写出文件到excel--------
  16.     print ("-----正在写入 "+str(i)+" 行")
  17.     sheet.write(i,1, label = sh.cell_value(i,3)) #向第1行第1列写入获取到的值
  18.     sheet.write(i,2, label = sh.cell_value(i,5)) #向第1行第2列写入获取到的值
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-19 19:19

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表