zoukankan      html  css  js  c++  java
  • 如何用Python修改Excel数据

    在前面的文章中介绍了如何用Python读写Excel数据,今天再介绍一下如何用Python修改Excel数据。需要用到xlutils模块。下载地址为https://pypi.python.org/pypi/xlutils。下载后执行python setup.py install命令进行安装即可。

    具体使用代码如下:

     1 #-*-coding:utf-8-*-
     2 from xlutils.copy import copy    # http://pypi.python.org/pypi/xlutils
     3 from xlrd import open_workbook  # http://pypi.python.org/pypi/xlrd
     4 from xlwt import easyxf         # http://pypi.python.org/pypi/xlwt
     5 
     6 import sys
     7 reload(sys)
     8 sys.setdefaultencoding('utf-8')
     9 
    10 # 0 based (subtract 1 from excel row number)
    11 START_ROW = 404
    12 
    13 ismal_index = 2
    14 #url所在列
    15 url_index = 12
    16 #domain所在列
    17 domain_index = 11
    18 #malinfo所在列
    19 malinfo_index = 9
    20 
    21 file_path = "C:\\Users\\***\\Desktop\\20130514.xls"
    22 #formatting_info=True保存之前数据的格式
    23 rb = open_workbook(file_path,formatting_info=True)
    24 r_sheet = rb.sheet_by_index(0) # read only copy to introspect the file
    25 wb = copy(rb) # a writable copy (I can't read values out of this, only write to it)
    26 w_sheet = wb.get_sheet(0) # the sheet to write to within the writable copy
    27 
    28 malurl = '''http://xbox.ooqqxx.com/res/ext.jar
    29             http://xbox.ooqqxx.com/res/stat.jar
    30             http://xbox.ooqqxx.com/pages/v.html
    31             http://xbox.ooqqxx.com/pages/extv.html
    32             http://xbox.ooqqxx.com/pages/r.html'''
    33 domain_info = "http://xbox.ooqqxx.com"
    34 malinfo = u"获取恶意URL,写入配置文件中,下载恶意可执行程序。"
    35 
    36 #r_sheet.nrows为总行数
    37 for row_index in range(START_ROW, r_sheet.nrows):
    38     #xlsvalue = r_sheet.cell(row_index, col_age_november).value
    39     w_sheet.write(row_index, ismal_index, u'')
    40     w_sheet.write(row_index, url_index, malurl)
    41     w_sheet.write(row_index, domain_index, domain_info)
    42     w_sheet.write(row_index, malinfo_index, malinfo)
    43 #wb.save(file_path + '.out' + os.path.splitext(file_path)[-1])
    44 wb.save("C:\\Users\\***\\Desktop\\2013.xls")
    注意:

    如果在写入数据(中文)时出现以下错误:

    ascii codec can't decode byte 0xe8 in position 0:ordinal not in range(128)

    则需加上以下代码:

    import sys
    reload(sys)
    sys.setdefaultencoding('utf-8')
    另外,则中文字符串前记得加上u.
     
  • 相关阅读:
    (转)Entity Framework 4.1 之三(由4.0过渡到4.1/4.3)
    (转)修改的T4代码生成器(续)
    (转)【Smart Code Generator】 基于T4的代码生成器
    linux下播放mp3
    poj 2777 Count Color
    poj 1062 昂贵的聘礼
    uva 991 Safe Salutations
    uva 10587 Mayor's posters
    poj 2528 Mayor's posters
    逆序数
  • 原文地址:https://www.cnblogs.com/goodhacker/p/3067394.html
Copyright © 2011-2022 走看看