如何将数据从一个工作表传输到另一个在同一工作簿中使用python?
问题描述:
我想使用python将'Sheet1'中的数据转移到工作表'Sheet2'中。使用python.I编写了下面的脚本,但面临着'IndexError:列表索引超出范围'。我知道这不是最好的办法。如果有人能以更有效的方式引导我,我会很感激。我共享Excel中的快照文件如下如何将数据从一个工作表传输到另一个在同一工作簿中使用python?
我可以直接进入“工作表Sheet1”单元格的值--->“Sheet2的”单元格的值,而不是做“工作表Sheet1”单元格的值--->列表--- - >'Sheet2'单元格值?
import openpyxl
wb = openpyxl.load_workbook('C:\Users\laban\Desktop\Par-emails1.xlsx')
type(wb)
wb.get_sheet_names()
sheet = wb.get_sheet_by_name('Sheet1')
type(sheet)
anotherSheet = wb.active
sheet1 = wb.get_sheet_by_name('Sheet2')
type(sheet1)
par=[sheet.cell(row= col, column=1).value for col in range(1, 2450)]
email_no=[sheet.cell(row= col, column=2).value for col in range(1, 2450)]
Domain=[sheet.cell(row= col, column=3).value for col in range(1, 2450)]
email=[sheet.cell(row= col, column=4).value for col in range(1, 2450)]
for x in range(0,2450):
if email_no[x]<9:
sheet1.cell(row= x+1, column=1).value=par[x]
sheet1.cell(row= x+1, column=2).value=email_no[x]
sheet1.cell(row= x+1, column=3).value=Domain[x]
sheet1.cell(row= x+1, column=4).value=email[x]
wb.save('C:\Users\laban\Desktop\Par-emails1.xlsx')
答
您可以使用:
wb = openpyxl.load_workbook('C:/Users/laban/Desktop/Par-emails1.xlsx')
sheet1 = wb.get_sheet_by_name('Sheet1')
sheet2 = wb.get_sheet_by_name('Sheet2')
for i,row in enumerate(sheet1.iter_rows()):
for j,col in enumerate(row):
sheet2.cell(row=i+1,column=j+1).value = col.value
显然,在2.4你可以用一个命令做到这一点:从什么我目前Copy whole worksheet with openpyxl
答
显然,这是非常简化的版本使用。 下面是一个代码片段,用于将sheet1中的数据无任何格式地复制到sheet2。 您不需要指定最大行数,最大列数,因为您可以使用 sheet.max_row
和sheet.max_columns
方法获取它。
from openpyxl.cell import Cell
max_row = sheet1.max_row #Get max row of first sheet
max_col = sheet1.max_column #Get max column of first sheet
for row_num in range(1,max_row + 1): #Iterate through rows
for col_num in range(1, max_col + 1): #Iterate through columns
_cell1 = sheet1.cell(row=row_num, column=col_num)
_cell2 = sheet2.cell(row=row_num, column=col_num)
_cell2.value = _cell1.value
增加了额外的变数以供理解。你可以在你的最后压缩。
答
伯尼可能有最好的答案在这里(复制整个工作表),但你的索引错误可能来自现身:更短的
par=[sheet.cell(row= col, column=1).value for col in range(1, 2450)]
为1细胞比:
for x in range(0,2450):
答
def excel_op():
filename='D://Python//excelread.xlsx'
sheet_name='Sheet1'
book = xlrd.open_workbook(str(filename))
sheet = book.sheet_by_name(sheet_name)
workbook = xlsxwriter.Workbook('excelwrite.xlsx')
worksheet = workbook.add_worksheet()
row_count = int(sheet.nrows)
col_count = int(sheet.ncols)
for row in range(0, int(row_count)):
for col in range(0, int(col_count)):
worksheet.write(row,col,str(sheet.cell(row, col).value))
workbook.close()
del book
在哪一行你有这个错误吗?错误信息总是伴随代码崩溃的(最新的)行号。它可以在'范围内的x(0,2450)'碰撞吗?记得openpyxl开始于1,而不是0。 – Elmex80s
及其索引在 文件 “C:/Users/laban/Excelpython.py” 崩溃,管线24,在 如果email_no [X]
我怀疑那条线上有'x = 0'。我对吗? – Elmex80s