zoukankan      html  css  js  c++  java
  • Python处理Excel文档之openpyxl (二)简单的使用

    简单的使用

    写一个工作表

     1 #coding:utf-8
     2 '''
     3 Created on 2018年8月18日
     4 
     5 @author: Administrator
     6 '''
     7 
     8 from openpyxl import Workbook
     9 from openpyxl.compat import range
    10 from openpyxl.utils import get_column_letter
    11 
    12 
    13 wb=Workbook()
    14 
    15 ws1=wb.active
    16 ws1.title="range names"
    17 for i in range(1,10):
    18     for j in range(1,5):
    19         ws1.cell(i,j)
    20         print(get_column_letter(j))

    根据索引,得到列的索引字符。

    A
    B
    C
    D....
    ...
    ...
    ...

    例子:

     1 #coding:utf-8
     2 '''
     3 Created on 2018年8月18日
     4 
     5 @author: Administrator
     6 '''
     7 
     8 from openpyxl import Workbook
     9 from openpyxl.compat import range
    10 from openpyxl.utils import get_column_letter
    11 
    12 wb=Workbook()
    13 new_filename="empty_book.xlsx"
    14 ws1=wb.active
    15 ws1.title="range names"
    16 
    17 for row in range(1,40):
    18     ws1.append(range(600))#使用了列表生成式
    19 
    20 ws2=wb.create_sheet("pi")
    21 ws2["F5"]=3.14
    22 
    23 ws3=wb.create_sheet("data")
    24 for row in range(10,20):
    25     for col in range(27,54):
    26         _ = ws3.cell(column=col, row=row, value="{0}".format(get_column_letter(col)))
    27 wb.save(filename=new_filename)
    28 
    29 # 
    30 # print(list(range(600)))使用了列表生成式

    读取一个存在的工作簿

    >>> from openpyxl import load_workbook
    >>> wb = load_workbook(filename = 'empty_book.xlsx')
    >>> sheet_ranges = wb['range names']
    >>> print(sheet_ranges['D18'].value)
    3
    

     

     1 #coding:utf8
     2 '''
     3 Created on 2018年8月18日
     4 
     5 @author: Administrator
     6 '''
     7 from openpyxl import load_workbook
     8 
     9 wb=load_workbook("empty_book.xlsx")
    10 sheet_ranges=wb['range names']
    11 print(sheet_ranges['D18'].value)
    View Code

    参数设置:

    load_workbook(filename, read_only, keep_vba, data_only, guess_types, keep_links)
    

      guess_types:将在读取单元格时启用或禁用(默认)类型推断。

          data_only控制有公式的单元格是否具有公式(默认值)或上次Excel读取表格时存储的值

          keep_vba控制是否保留了任何Visual Basic元素(默认)。如果它们被保存,它们仍然是不可编辑的

    重要的事说:三遍。说:“三遍。OK”

         openpyxl目前没有读取Excel文件中的所有可能项,因此如果以相同的名称打开和保存现有文件,图像和图表就会丢失。

    Using number formats

    >>> import datetime
    >>> from openpyxl import Workbook
    >>> wb = Workbook()
    >>> ws = wb.active
    >>> # set date using a Python datetime
    >>> ws['A1'] = datetime.datetime(2010, 7, 21)
    >>>
    >>> ws['A1'].number_format
    'yyyy-mm-dd h:mm:ss'
    >>> # You can enable type inference on a case-by-case basis
    >>> wb.guess_types = True
    >>> # set percentage using a string followed by the percent sign
    >>> ws['B1'] = '3.14%'
    >>> wb.guess_types = False
    >>> ws['B1'].value
    0.031400000000000004
    >>>
    >>> ws['B1'].number_format
    '0%'
    

      

     1 #coding:utf-8
     2 '''
     3 Created on 2018年8月18日
     4 
     5 @author: Administrator
     6 '''
     7 import datetime
     8 from openpyxl import Workbook
     9 
    10 
    11 
    12 wb=Workbook()
    13 ws=wb.active
    14 
    15 ws['A1']=datetime.datetime(2010,7,20)
    16 
    17 print(ws['A1'].value)
    18 #2010-07-20 00:00:00
    19 a1=ws['A1'].number_format
    20 print(a1)
    21 #yyyy-mm-dd h:mm:ss
    22 wb.guess_types=True#您可以根据具体情况启用类型推断
    23 b1=ws['B1']='3.14%'#使用百分号的字符串设置百分数
    24 print(b1)#3.14%
    25 wb.guess_types=False
    26 b1_1=ws['B1'].value
    27 print(b1_1)
    28 #0.031400000000000004
    29 print(ws['B1'].number_format)
    30 #0%
    View Code

    使用表格公式

    >>> from openpyxl import Workbook
    >>> wb = Workbook()
    >>> ws = wb.active
    >>> # add a simple formula
    >>> ws["A1"] = "=SUM(1, 1)"
    >>> wb.save("formula.xlsx")

    注意:你必须使用英文名作为函数名,函数参数必须用逗号分隔,而不是其他标点符号,如分号。

    openpyxl从不计算公式,但可以检查公式的名称: 检查函数的名称是否可用。

    >>> from openpyxl.utils import FORMULAE
    >>> "HEX2DEC" in FORMULAE
    True
    

      如果您试图使用一个不知道的公式,这可能是因为您使用的公式没有包含在最初的规范中。这些公式必须以_xlfn为前缀。去工作。

    合并单元格、拆分单元格

    当您合并单元格时,除左上角单元格外的所有单元格都将从工作表中删除。有关格式化合并单元格的信息,请参阅样式合并单元格。

    >>> from openpyxl.workbook import Workbook
    >>>
    >>> wb = Workbook()
    >>> ws = wb.active
    >>>
    >>> ws.merge_cells('A2:D2')
    >>> ws.unmerge_cells('A2:D2')
    >>>
    >>> # or equivalently
    >>> ws.merge_cells(start_row=2, start_column=1, end_row=4, end_column=4)
    >>> ws.unmerge_cells(start_row=2, start_column=1, end_row=4, end_column=4)
    

    插入图像

    >>> from openpyxl import Workbook
    >>> from openpyxl.drawing.image import Image
    >>>
    >>> wb = Workbook()
    >>> ws = wb.active
    >>> ws['A1'] = 'You should see three logos below'
    

      

    >>> # create an image
    >>> img = Image('logo.png')
    

      

    >>> # add to worksheet and anchor next to cells
    >>> ws.add_image(img, 'A1')
    >>> wb.save('logo.xlsx')
    

      

    分级显示。组合,取消组合,分类汇总

    1 >>> import openpyxl
    2 >>> wb = openpyxl.Workbook()
    3 >>> ws = wb.create_sheet()
    4 >>> ws.column_dimensions.group('A','D', hidden=True)
    5 >>> ws.row_dimensions.group(1,10, hidden=True)
    6 >>> wb.save('group.xlsx')



    只读模式

     有时候,您需要打开或编写非常大的XLSX文件,而openpyxl中的通用例程无法处理这种负载。幸运的是,有两种模式允许您使用(接近)恒定的内存消耗读写无限数量的数据

     隆重介绍一下:openpyxl.worksheet.read_only.ReadOnlyWorksheet 

    from openpyxl import load_workbook
    wb = load_workbook(filename='large_file.xlsx', read_only=True)
    ws = wb['big_data']
    
    for row in ws.rows:
        for cell in row:
            print(cell.value)
    

    返回的单元格不是常规的 openpyxl.cell.cell ,是 openpyxl.cell.read_only.ReadOnlyCell 

    工作表维度

    只读模式依赖于创建文件的应用程序和库,这些应用程序和库提供关于工作表的正确信息,特别是它使用的部分,即维度。有些应用程序设置错误。可以使用ws.calculate_dimension()检查工作表的表观维数。如果这返回了一个您知道不正确的范围,比如A1:A1,那么只需重新设置max_row和max_column属性就可以使用文件:

    ws.max_row = ws.max_column = None
    

      

  • 相关阅读:
    SAP基础:定位点运算
    WDA基础十七:ALV不同行显示不同下拉
    WDA基础十六:ALV的颜色
    WEB UI基础八:链接跳转到标准的工单界面
    WDA基础十五:POPUP WINDOW
    CRM创建BP(END USER)
    CRM 员工创建并分配用户
    STRANS一:简单的XML转换
    WEB UI 上传URL附件(使用方法备份)
    FPM四:用OVP做查询跳转到明细
  • 原文地址:https://www.cnblogs.com/Mengchangxin/p/9496937.html
Copyright © 2011-2022 走看看