用python编写的excel拆分小工具

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用python编写的excel拆分小工具相关的知识,希望对你有一定的参考价值。

from datetime import date,datetime

from openpyxl import Workbook

from openpyxl import load_workbook

from openpyxl.styles import Border, Side, Font,Alignment

from tkinter import *

from tkinter import filedialog

from tkinter import messagebox

‘‘‘

设置单元格样式

‘‘‘

‘‘‘ 

def set_style(name,height,bold=False):

  style = xlwt.XFStyle() # 初始化样式

 

  font = xlwt.Font() # 为样式创建字体

  font.name = name # ‘Times New Roman‘

  font.bold = bold

  font.color_index = 4

  font.height = height

  style.font = font

  # style.borders = borders

 

  return style

  ‘‘‘

‘‘‘

def create_file(rows,nrows,ncols,filename):

    f = xlwt.Workbook()                  #创建工作簿                                                        

    sheet1 = f.add_sheet(u‘sheet1‘,cell_overwrite_ok=True) #创建第一个sheet:

    for i in range(0,nrows):

        for m in range(0,ncols):

          sheet1.write(i,m,rows[i][m],set_style("楷体",300,bold=False))#write(行索引,列列索引,要写入的值,字体)

          sheet1.col(m).width = 0x0d00 + m*2500  #设置行宽度

 

    f.save(filename+‘.xls‘)

‘‘‘

 

‘‘‘

border = Border(left=Side(border_style=None,color=‘FF000000‘),\

                right=Side(border_style=None,color=‘FF000000‘),\

                top=Side(border_style=None,color=‘FF000000‘),\

                bottom=Side(border_style=None,color=‘FF000000‘),\

                diagonal=Side(border_style=None,color=‘FF000000‘),\

                diagonal_direction=10,outline=Side(border_style=None,color=‘FF000000‘),\

                vertical=Side(border_style=None,color=‘FF000000‘),\

                horizontal=Side(border_style=None,color=‘FF000000‘))

alignment=Alignment(horizontal=‘general‘,vertical=‘bottom‘,\

          text_rotation=0,wrap_text=False,shrink_to_fit=False,indent=0)

‘‘‘

font = Font(name=‘楷体‘,size=15,bold=False,italic=False,\

            vertAlign=None,underline=‘none‘,strike=False,color=‘FF000000‘)

 

def create_file(rows,nrows,ncols,filename):

    f = Workbook()                  #创建工作簿                                                        

    sheet = f.active #创建第一个sheet:

    for i in range(1,nrows+1):

        for m in range(1,ncols+1):

          #write(行索引,列列索引,要写入的值,字体)

          sheet.cell(row = i,column = m,value = rows[i-1][m-1]).font = font

          #sheet.cell(row = i,column = m).border = border

          #sheet.cell(row = i,column = m).alignment = alignment

          #sheet1.col(m).width = 0x0d00 + m*2500  #设置行宽度

          #下一句为改变列宽的方法,还是从国外网站找的,非常有用

          sheet.column_dimensions[sheet.cell(row = i,column = m).column].width = 30

    f.save(filename_save+filename+‘.xlsx‘)

    

def create_list(list_name):

    list_name = []

    return list_name

    

def main(filepath,col_str):

  #workbook = xlrd.open_workbook(filepath)

  wb = load_workbook(filename = filepath,data_only = True)#不读取公式

  sheetnames = wb.get_sheet_names()

  sheet = wb.get_sheet_by_name(sheetnames[0])

  nrows = sheet.max_row

  ncols = sheet.max_column

  #print(nrows)

  #sheet = workbook.sheet_by_index(0) # sheet索引从0开始

  ‘‘‘

  # 获取所有sheet

  #print(workbook.sheet_names()) # [u‘sheet1‘, u‘sheet2‘]

  #sheet2_name = workbook.sheet_names()[1]

   

  # 根据sheet索引或者名称获取sheet内容

 

  #sheet2 = workbook.sheet_by_name(‘sheet2‘)

   

  # sheet的名称,行数,列数

  #print(sheet.name,sheet.nrows,sheet.ncols,type(sheet.nrows))

 

  # 获取整行和整列的值(数组)

  ‘‘‘

 

  rows = []

  col_num = 0

  row_num = 0

  for i in range(1,nrows+1):

    list_temp = []

    for m in range(1,ncols+1):

      data = sheet.cell(row=i,column=m).value

      #print(type(data))

      #获取划分条件所在的列数,作为main函数的参数传入

      if data == col_str:

        col_num = m

        row_num = i

      if (type(data) == datetime):

        #转换日期,更加方便,无需datemode打开

        data = data.strftime(‘%Y/%m/%d‘)

      list_temp.append(data) #循环获取表格的所有内容

    rows.append(list_temp)

                                       #cols = sheet.col_values(2) # 获取第三列内容

  #print(rows)

  list_name = []

  for i in range(1,nrows+1):    

    list_name.append(str(sheet.cell(row = i,column = col_num).value))

  list_name.append("None")

  list_name_unique = list(set(list_name))

  list_name_unique.remove(col_str)

  list_name_unique.remove("None")#目的是去除空值,这里空值显示为None

 

  for m in list_name_unique:

      list_num = [rows[row_num-1]]#col_num为逻辑序号,需要做-1处理

      for i in range(0,nrows):

          if m == rows[i][col_num-1]:            

              list_num.append(rows[i])       

      create_file(list_num,len(list_num),ncols,m)

  messagebox.showinfo(‘提示框‘,‘拆分成功‘,default = ‘ok‘)

 

root = Tk()

def choosefile():

  filename_file = filedialog.askopenfilename()

  global filename_save

  filename_save = filename_file.rsplit(sep = ‘/‘,maxsplit = 1)[0]+‘/‘  

  e_file.delete(0,END)

  e_file.insert(0,filename_file)

 

#判断拆分按钮是否可用

def checkButton1(a):

    if a.strip() == ""or v2.get().strip() == "":

        bton2[‘state‘] = DISABLED

        return True

    else:

        bton2[‘state‘] = NORMAL

        return True

def checkButton2(a):

 

    if a.strip() == ""or v1.get().strip() == "":

        bton2[‘state‘] = DISABLED

        return True

    else:

        bton2[‘state‘] = NORMAL

        return True

 

Label(root,text = "文件").grid(row = 0)

Label(root,text = "字段").grid(row = 1)

 

bton1 = Button(root,text = "选择文件",width = 10,command = choosefile)

bton1.grid(row = 3,column = 0,sticky = W,padx = 10,pady = 5)

 

bton2 = Button(root,text = "开始拆分",state = DISABLED,width = 10,command = lambda:main(e_file.get(),e_name.get()))

bton2.grid(row = 3,column = 1,sticky = E,padx = 10,pady = 5)

 

checkButtonCMD1 = root.register(checkButton1)

checkButtonCMD2 = root.register(checkButton2)

v1 = StringVar()

v2 = StringVar()

e_file = Entry(root,textvariable = v1,validate = "key",validatecommand = (checkButtonCMD1,‘%P‘))

e_name = Entry(root,textvariable = v2,validate = "key",validatecommand = (checkButtonCMD2,‘%P‘))

 

e_file.grid(row = 0,column = 1,padx = 10,pady = 5)

e_name.grid(row = 1,column = 1,padx = 10,pady = 5)

 

 

mainloop()

 

from datetime import date,datetime

from openpyxl import Workbook

from openpyxl import load_workbook

from openpyxl.styles import Border, Side, Font,Alignment

from tkinter import *

from tkinter import filedialog

from tkinter import messagebox

‘‘‘

设置单元格样式

‘‘‘

‘‘‘

def set_style(name,height,bold=False):

  style = xlwt.XFStyle() # 初始化样式

 

  font = xlwt.Font() # 为样式创建字体

  font.name = name # ‘Times New Roman‘

  font.bold = bold

  font.color_index = 4

  font.height = height

  style.font = font

  # style.borders = borders

 

  return style

  ‘‘‘

‘‘‘

def create_file(rows,nrows,ncols,filename):

    f = xlwt.Workbook()                  #创建工作簿                                                       

    sheet1 = f.add_sheet(u‘sheet1‘,cell_overwrite_ok=True) #创建第一个sheet:

    for i in range(0,nrows):

        for m in range(0,ncols):

          sheet1.write(i,m,rows[i][m],set_style("楷体",300,bold=False))#write(行索引,列列索引,要写入的值,字体)

          sheet1.col(m).width = 0x0d00 + m*2500  #设置行宽度

 

    f.save(filename+‘.xls‘)

‘‘‘

 

‘‘‘

border = Border(left=Side(border_style=None,color=‘FF000000‘),\

                right=Side(border_style=None,color=‘FF000000‘),\

                top=Side(border_style=None,color=‘FF000000‘),\

                bottom=Side(border_style=None,color=‘FF000000‘),\

                diagonal=Side(border_style=None,color=‘FF000000‘),\

                diagonal_direction=10,outline=Side(border_style=None,color=‘FF000000‘),\

                vertical=Side(border_style=None,color=‘FF000000‘),\

                horizontal=Side(border_style=None,color=‘FF000000‘))

alignment=Alignment(horizontal=‘general‘,vertical=‘bottom‘,\

          text_rotation=0,wrap_text=False,shrink_to_fit=False,indent=0)

‘‘‘

font = Font(name=‘楷体‘,size=15,bold=False,italic=False,\

            vertAlign=None,underline=‘none‘,strike=False,color=‘FF000000‘)

 

def create_file(rows,nrows,ncols,filename):

    f = Workbook()                  #创建工作簿                                                        

    sheet = f.active #创建第一个sheet:

    for i in range(1,nrows+1):

        for m in range(1,ncols+1):

          #write(行索引,列列索引,要写入的值,字体)

          sheet.cell(row = i,column = m,value = rows[i-1][m-1]).font = font

          #sheet.cell(row = i,column = m).border = border

          #sheet.cell(row = i,column = m).alignment = alignment

          #sheet1.col(m).width = 0x0d00 + m*2500  #设置行宽度

          #下一句为改变列宽的方法,还是从国外网站找的,非常有用

          sheet.column_dimensions[sheet.cell(row = i,column = m).column].width = 30

    f.save(filename_save+filename+‘.xlsx‘)

   

def create_list(list_name):

    list_name = []

    return list_name

   

def main(filepath,col_str):

  #workbook = xlrd.open_workbook(filepath)

  wb = load_workbook(filename = filepath,data_only = True)#不读取公式

  sheetnames = wb.get_sheet_names()

  sheet = wb.get_sheet_by_name(sheetnames[0])

  nrows = sheet.max_row

  ncols = sheet.max_column

  #print(nrows)

  #sheet = workbook.sheet_by_index(0) # sheet索引从0开始

  ‘‘‘

  # 获取所有sheet

  #print(workbook.sheet_names()) # [u‘sheet1‘, u‘sheet2‘]

  #sheet2_name = workbook.sheet_names()[1]

  

  # 根据sheet索引或者名称获取sheet内容

 

  #sheet2 = workbook.sheet_by_name(‘sheet2‘)

  

  # sheet的名称,行数,列数

  #print(sheet.name,sheet.nrows,sheet.ncols,type(sheet.nrows))

 

  # 获取整行和整列的值(数组)

  ‘‘‘

 

  rows = []

  col_num = 0

  row_num = 0

  for i in range(1,nrows+1):

    list_temp = []

    for m in range(1,ncols+1):

      data = sheet.cell(row=i,column=m).value

      #print(type(data))

      #获取划分条件所在的列数,作为main函数的参数传入

      if data == col_str:

        col_num = m

        row_num = i

      if (type(data) == datetime):

        #转换日期,更加方便,无需datemode打开

        data = data.strftime(‘%Y/%m/%d‘)

      list_temp.append(data) #循环获取表格的所有内容

    rows.append(list_temp)

                                       #cols = sheet.col_values(2) # 获取第三列内容

  #print(rows)

  list_name = []

  for i in range(1,nrows+1):   

    list_name.append(str(sheet.cell(row = i,column = col_num).value))

  list_name.append("None")

  list_name_unique = list(set(list_name))

  list_name_unique.remove(col_str)

  list_name_unique.remove("None")#目的是去除空值,这里空值显示为None

 

  for m in list_name_unique:

      list_num = [rows[row_num-1]]#col_num为逻辑序号,需要做-1处理

      for i in range(0,nrows):

          if m == rows[i][col_num-1]:           

              list_num.append(rows[i])      

      create_file(list_num,len(list_num),ncols,m)

  messagebox.showinfo(‘提示框‘,‘拆分成功‘,default = ‘ok‘)

 

root = Tk()

def choosefile():

  filename_file = filedialog.askopenfilename()

  global filename_save

  filename_save = filename_file.rsplit(sep = ‘/‘,maxsplit = 1)[0]+‘/‘ 

  e_file.delete(0,END)

  e_file.insert(0,filename_file)

 

#判断拆分按钮是否可用

def checkButton1(a):

    if a.strip() == ""or v2.get().strip() == "":

        bton2[‘state‘] = DISABLED

        return True

    else:

        bton2[‘state‘] = NORMAL

        return True

def checkButton2(a):

 

    if a.strip() == ""or v1.get().strip() == "":

        bton2[‘state‘] = DISABLED

        return True

    else:

        bton2[‘state‘] = NORMAL

        return True

 

Label(root,text = "文件").grid(row = 0)

Label(root,text = "字段").grid(row = 1)

 

bton1 = Button(root,text = "选择文件",width = 10,command = choosefile)

bton1.grid(row = 3,column = 0,sticky = W,padx = 10,pady = 5)

 

bton2 = Button(root,text = "开始拆分",state = DISABLED,width = 10,command = lambda:main(e_file.get(),e_name.get()))

bton2.grid(row = 3,column = 1,sticky = E,padx = 10,pady = 5)

 

checkButtonCMD1 = root.register(checkButton1)

checkButtonCMD2 = root.register(checkButton2)

v1 = StringVar()

v2 = StringVar()

e_file = Entry(root,textvariable = v1,validate = "key",validatecommand = (checkButtonCMD1,‘%P‘))

e_name = Entry(root,textvariable = v2,validate = "key",validatecommand = (checkButtonCMD2,‘%P‘))

 

e_file.grid(row = 0,column = 1,padx = 10,pady = 5)

e_name.grid(row = 1,column = 1,padx = 10,pady = 5)

 

 

mainloop()

以上是关于用python编写的excel拆分小工具的主要内容,如果未能解决你的问题,请参考以下文章

EXCEL表格有拆分功能吗

基于pywebview的桌面小工具开发记录

python+xlsxwriter+PIL自动压图贴图到Excel小工具

PyQt5 小工具:Excel数据分组汇总器...

偷懒小工具 - Excel导出公共类

巧用批处理工具分析monkey日志