python操作excelで作業を自動化
4382 ワード
0x00
ある局のある指導者は3つのexcelファイルをあげて、1つの中に4つのsheetが処理しなければならなくて、1つのsheetは250+列があって、計算すると全部で3000+列が手動で繰り返し挿入して、列を削除して、コピーして、和を求めて、だから4日間の時間をあげて完成します.
私は大量の簡単で重複的な仕事をしたくなくて、3つの表のフォーマットを見て基本的に同じで、そこでpythonで30行のコードを書いてこの“困難な”任務を完成しました.
0x01
pythonでexcelを操作するには、xlrd、xlwt(または他のモジュールでもいい)をインストールする必要があります.
EXcelファイルの読み込み:workbook=xlrd.open_workbook('filename.xlsx')
すべてのテーブル名を取得:sheet_names = workbook.sheet_names()
インデックス順でワークシートを取得します:sheet 0=workbook.sheets()[0] || sheet1 = workbook.sheet_by_index(1)
名前からワークシートを取得:sheet 3=data.sheet_by_name(u'sheetname')
テーブルの行、列のサイズを取得:rows=sheet.nrows || cols = sheet.ncols
指定した行、列の値を取得:col 0_value = sheet.col_valsue(0) || row0_value = sheet.row_values(0)
作業オブジェクトの作成:wk=xlwt.Workbook(encoding='utf-8')
sheetオブジェクトの追加:sheet 0=wk.add_sheet(sheetname,cell_overwrite=True)
セルに値を書き込む:sheet 0.write(row,col,value)
保存ファイル:wk.save('filename.xls')
0x02
ある局のある指導者は3つのexcelファイルをあげて、1つの中に4つのsheetが処理しなければならなくて、1つのsheetは250+列があって、計算すると全部で3000+列が手動で繰り返し挿入して、列を削除して、コピーして、和を求めて、だから4日間の時間をあげて完成します.
私は大量の簡単で重複的な仕事をしたくなくて、3つの表のフォーマットを見て基本的に同じで、そこでpythonで30行のコードを書いてこの“困難な”任務を完成しました.
0x01
pythonでexcelを操作するには、xlrd、xlwt(または他のモジュールでもいい)をインストールする必要があります.
EXcelファイルの読み込み:workbook=xlrd.open_workbook('filename.xlsx')
すべてのテーブル名を取得:sheet_names = workbook.sheet_names()
インデックス順でワークシートを取得します:sheet 0=workbook.sheets()[0] || sheet1 = workbook.sheet_by_index(1)
名前からワークシートを取得:sheet 3=data.sheet_by_name(u'sheetname')
テーブルの行、列のサイズを取得:rows=sheet.nrows || cols = sheet.ncols
指定した行、列の値を取得:col 0_value = sheet.col_valsue(0) || row0_value = sheet.row_values(0)
作業オブジェクトの作成:wk=xlwt.Workbook(encoding='utf-8')
sheetオブジェクトの追加:sheet 0=wk.add_sheet(sheetname,cell_overwrite=True)
セルに値を書き込む:sheet 0.write(row,col,value)
保存ファイル:wk.save('filename.xls')
0x02
# coding=utf-8
import xlrd
import xlwt
workbook = xlrd.open_workbook('2014 .xlsx')
sheet_names = workbook.sheet_names()
#
sheet0 = workbook.sheets()[0]
sheet1 = workbook.sheet_by_index(1)
sheet2 = workbook.sheet_by_index(2)
sheet3 = workbook.sheet_by_index(3)
sheet4 = workbook.sheet_by_index(4)
sheet5 = workbook.sheet_by_index(5)
sheet6 = workbook.sheet_by_index(6)
sheet7 = workbook.sheet_by_index(7)
sheet8 = workbook.sheet_by_index(8)
#
#table = data.sheet_by_name(u'Sheet1')
# 、
sht0_rows = sheet0.nrows
sht0_cols = sheet0.ncols
#
temp = sheet0.cell(0,2)
# 、
temp_col0 = sheet0.col_values(0)
temp_row0 = sheet0.row_values(0)
temp_col1 = sheet0.col_values(1)
temp_row1 = sheet0.row_values(1)
# 204 tb0_rows
'''
for i in range(204/6):# 34
for j in temp_row:
j[2:8]
'''
#print(tb0_rows,tb0_cols,temp,temp_row,temp_row[2:8],temp_col)
#
#print(temp_row[2:206])
wk = xlwt.Workbook(encoding='utf-8')
wk_lst = []# sheet
for shtname in sheet_names:
#print(shtname)
wk_lst.append(wk.add_sheet(shtname,cell_overwrite_ok=True))
#print(len(wk_lst))
'''
for c in range(len(temp_col0)):
wk_lst[0].write(c,0,temp_col0[c])
#print(temp_col[c])
'''
# sheet
xlrd_sheet_list = [sheet0,sheet1,sheet2,sheet3]
for tm in range(len(wk_lst)):
if tm<4:
'''1. '''
for x in range(2):
#print('----------x:',x)
temp_col = sheet0.col_values(x)
for c in range(len(temp_col)):
#print('--------c:',c)
#print(temp_col[c])
wk_lst[tm].write(c,x,temp_col[c])
temp_row = sheet0.row_values(0)
for r in range(len(temp_row)-2):
#print(tm,len(temp_row))
wk_lst[tm].write(0,r+2,temp_row[r+2])
'''2. '''
for r in range(2,13):#
tmp_row = xlrd_sheet_list[tm].row_values(r)
w = tmp_row[2:206] #
#print(len(w) / 6)
x = 0
for i in range(int(len(w) / 6)):
sum_pf = round(w[0 + x] + w[1 + x] + w[2 + x] + w[3 + x] + w[4 + x] + w[5 + x], 2)
wk_lst[tm].write(r,2+x,sum_pf)
print(sum_pf)
x += 6
print("----------------------------------------r:",r,2+x,sum_pf)
#for i in range(2,13):
# print(i)
wk.save('nb.xls')
'''# excel
wkt = xlwt.Workbook()
ws = wkt.add_sheet('CO')
ws.write(0,0,'1')
wkt.save('fuck.xls')
'''
'''
#
for r in range(2,13):#
tmp_row = sheet0.row_values(r)
w = tmp_row[2:206] #
#print(len(w) / 6)
x = 0
y = 0
for i in range(int(len(w) / 6)):
#wk_lst[0].write(2+)
print(round(w[0 + x] + w[1 + x] + w[2 + x] + w[3 + x] + w[4 + x] + w[5 + x], 2))
x += 6
print("----------------------------------------",r)
'''
'''#
w = temp_row[2:206]#
print(len(w)/6)
x=0
for i in range(int(len(w)/6)):
print(round(w[0+x]+w[1+x]+w[2+x]+w[3+x]+w[4+x]+w[5+x],2))
x+=6
'''