025 使用集合方法拼接两个工作表

此案例主要通过使用Python语言的集合的union()方法合并两个集合的成员,从而实现在工作簿中拼接两个工作表。当运行此案例的Python代码(A346.py文件)之后,将根据“订单表.xlsx”文件的已出库订单表和未出库订单表拼接全部订单表,已出库订单表如图025-1所示,未出库订单表如图025-2所示,拼接的全部订单表如图025-3所示。

图025-1

图025-2

图025-3

A346.py文件的Python代码如下:

import openpyxl
myBook=openpyxl.load_workbook('订单表.xlsx',data_only=True)
mySheet1=myBook['已出库订单表']
mySheet2=myBook['未出库订单表']
#将已出库订单表复制成全部订单表
mySheet3=myBook.copy_worksheet(mySheet1)
mySheet3.title='全部订单表'
#删除全部订单表的行(第1行除外)
while mySheet3.max_row >1:
      mySheet3.delete_rows(2)
#根据已出库订单表的行创建集合(mySet1)
mySet1=set(list(mySheet1.values)[1:])
#根据未出库订单表的行创建集合(mySet2)
mySet2=set(list(mySheet2.values)[1:])
#将mySet1和mySet2拼接成mySet3,即生成全部订单表
mySet3=mySet1.union(mySet2)
for myRow in mySet3:
    mySheet3.append(myRow)
myBook.save('结果表-订单表.xlsx')

在上面这段代码中,mySet3=mySet1.union(mySet2)表示将mySet1集合和mySet2集合拼接成mySet3集合。注意:mySet3集合成员的排列顺序可能与它们在mySet1集合和mySet2集合中的排列顺序不一致,并且可能每次在拼接之后的排列顺序都不一致,因为集合的成员与排列顺序无关。

此案例的源文件是MyCode\A346\A346.py。