首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Python 3 xlutils+xlrd+xlwt

Python 3 xlutils+xlrd+xlwt
EN

Stack Overflow用户
提问于 2018-10-19 16:37:14
回答 1查看 387关注 0票数 0

我正在使用xlrd/xlwt/xlutils编辑现有的xls工作簿,我可以更改xlrd工作簿中的值,但我需要将它们写入现有的工作簿中。我的代码不工作,我知道alghorytm是正确的,但代码不是。

代码语言:javascript
复制
  rb = open_workbook(filename)
#set active sheet
rs = rb.sheet_by_index(0)
#make instance for xlsutils
wb = copy(rb)
ws = wb.get_sheet(0)

rows = rs.nrows
cols = rs.ncols
#iterate and prepare format for SQL db tables
for row_idx in range (0,rows):
    for col_idx in range (0,cols):
        cell=rs.cell(row_idx,col_idx)
        clval = cell.value
        cltp = cell.ctype
        if cltp == xlrd.XL_CELL_BLANK:
           clval ="xy"
           ws.write(row_idx,col_idx,"xy")
        elif cltp == xlrd.XLDateError:
            date_format = XFStyle()
            date_format.num_format_str = 'dd/MM/yyyy'
            clval = '01/01/2018'
            ws.write(row_idx,col_idx, '01/01/2018', date_format)
        elif cltp == xlrd.XL_CELL_EMPTY:
            clval="XYU"
            ws.write(row_idx,col_idx,"xy")
        elif cltp == xlrd.XL_CELL_NUMBER:
            if clval < 0:
             clval=0
             ws.write(row_idx, col_idx,0)
        elif cltp == xlrd.XL_CELL_TEXT:
             clval = ftfy.fix_text(clval)
             ws.write(row_idx,col_idx, ftfy.fix_text(clval))

        elif clval == -693594:
             date_format = XFStyle()
             date_format.num_format_str = 'dd/MM/yyyy'
             clval='01/01/2018'
             ws.write(row_idx, col_idx,'01/01/2018',date_format)
             #print (row_idx,col_idx)
        print(clval)
        save(wb,'abbcards_2.xls')

Output:
 File "D:/rs_al/IdeaProjects/ExcelToSQL/PyXLSSQL/XLStoSQL.py", line 69, in 
 xls_wrk
save(wb,'abbcards_2.xls')
File "C:\Python\lib\site-packages\xlutils\save.py", line 24, in save
StreamWriter(stream)
File "C:\Python\lib\site-packages\xlutils\filter.py", line 941, in process
reader(chain[0])
File "C:\Python\lib\site-packages\xlutils\filter.py", line 65, in __call__
filter.workbook(workbook,filename)
File "C:\Python\lib\site-packages\xlutils\filter.py", line 291, in workbook
self.wtbook.dates_1904 = rdbook.datemode
AttributeError: 'Workbook' object has no attribute 'datemode'

我假设我打印xlrd工作簿的内存实例中存在,值是正确的。但是如何编写它们呢?

我不明白从xlutils复制到底有什么用。它会产生另一个物体吗?如果是这样,如何使用xlrd+xlwt进行编写?我发现不能使用pandas,因为我需要确切地知道细胞类型,才能在那里改变值。

在java中,我用一个包做了同样的事情,其中有在同一对象中读/写/保存的方法。

EN

回答 1

Stack Overflow用户

发布于 2018-10-23 22:59:34

唯一有效的方法是:

  1. 使用xlrd
  2. 打开工作簿迭代并获取单元格值
  3. 使用xlwt

创建新工作簿

通过迭代复制单元格值

对于日期,为Excel dd/mm/yyyy创建适当的样式。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52888705

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档