主頁 > 前端設計 > 6000字長文,帶你用Python完成 “Excel合并(拆分)” 的各種操作!

6000字長文,帶你用Python完成 “Excel合并(拆分)” 的各種操作!

2020-10-26 13:37:16 前端設計

一、概述

在這里插入圖片描述
其實Excel合并這個需求,應該是一個極為普遍的需求了,今天我們就利用Python完成“Excel合并(拆分)” 操作,具體如下:

  • ① 將多個Excel表,合并到一個Excel中(每個Excel中只有一個sheet表);
  • ② 將多個Excel表,合并到一個Excel中(每個Excel中不只一個sheet表);
  • ③ 將一個Excel表中的多個sheet表合并,并保存到同一個excel;
  • ④ 將一個Excel表,按某一列拆分成多張表;

二、知識點講解

在這里插入圖片描述
其實完成這些操作,涉及到了太多的知識點,因此在講述上述這個知識點以前,我們要帶大家復習一些常用的知識點,

  • ① os模塊常用知識點講解;
  • ② pandas模塊常用知識點講解;
  • ③ xlsxwriter模塊常用知識點講解;
  • ④ xlrd常用知識點講解;

1. os模塊知識點講解

對于os模塊,我們主要講述os.walk()、os.path.join()等知識點,

1.1 os.walk()

對于這個知識點,我們需要說明以下幾點:

  • os.walk()的回傳值是一個生成器(generator),我們需要回圈遍歷它,來獲取其中的內容;
  • 每次遍歷,回傳的都是一個三元組(path, dirs, files);
  • path:回傳的是當前正在遍歷的這個檔案夾的,本身路徑地址;
  • dirs:回傳的是該檔案夾中所有目錄的名字(不包含子目錄),有多少個都以“串列”回傳;
  • files:回傳的是該檔案夾中所有的檔案(不包含子目錄下的檔案),有多少個都以“串列”回傳;

如果說,有一個如圖所示的檔案夾,
在這里插入圖片描述
利用下方的代碼,我們可以得到什么結果呢?

pwd = "G:\\a"
print(os.walk(pwd))
for i in os.walk(pwd):
    print(i)
for path,dirs,files in os.walk(pwd):
    print(files)```

結果如下:

<generator object walk at 0x0000029BB5AEAB88>
('G:\\a', [], ['aa.txt', 'bb.xlsx', 'cc.txt', 'dd.docx'])
['aa.txt', 'bb.xlsx', 'cc.txt', 'dd.docx']
1.2 os.path.join()

這個函式,主要用于將多個路徑組合后回傳,超級簡單,就不做過多闡述,

path1 = 'G:\\a'
path2 = 'aa.txt'
print(os.path.join(path1,path2))

結果如下:

G:\a\aa.txt

2. pandas模塊知識點講解

由于是需要利用Pandas進行Excel的合并,因此我們要學會,如何利用Pandas進行資料的縱向合并,

我們先創建2個資料框(DataFrame):

import numpy as np
xx = np.arange(15).reshape(5,3)
yy = np.arange(1,16).reshape(5,3)
xx = pd.DataFrame(xx,columns=["語文","數學","外語"])
yy = pd.DataFrame(yy,columns=["語文","數學","外語"])
print(xx)
print(yy)

效果如下:
在這里插入圖片描述
接著,可以利用Pandas中的concat()函式,完成縱向拼接的操作,

  • pd.concat(list)中【默認axis=0】默認的是資料的縱向合并;
  • pd.concat(list)括號中傳入的是一個串列;
  • ignore_list=True表示忽略原有索引,重新生成一組新的索引;
  • 或者直接可以寫成z = pd.concat([xx,yy],ignore_list=True);
concat_list = []
concat_list.append(xx)
concat_list.append(yy)
z = pd.concat(concat_list,ignore_list=True)
print(z)

效果如下:
在這里插入圖片描述

3. xlsxwriter模塊知識點講解

xlsxwriter模塊一般是和xlrd模塊搭配使用的,
xlsxwriter:負責寫入資料,
xlrd:負責讀取資料,
接下來,我們分別對這兩個庫的常見用法,進行介紹,

1)如何創建一個“作業簿”?
import xlsxwriter

# 這一步相當于創建了一個新的"作業簿";
# "demo.xlsx"檔案不存在,表示新建"作業簿";
# "demo.xlsx"檔案存在,表示新建"作業簿"覆寫原有的"作業簿";
workbook = xlsxwriter.Workbook("demo.xlsx")

# close是將"作業簿"保存關閉,這一步必須有,否則創建的檔案無法顯示出來,
workbook.close() 
2)如何添加一個“Sheet作業表”

我們知道,一個Excel檔案就是一個Excel作業簿,而每一個作業簿中,又有很多的“Sheet作業表”,接下來,我們如何用代碼實作這個操作呢?

import xlsxwriter

workbook = xlsxwriter.Workbook("cc.xlsx")
worksheet = workbook.add_worksheet("2018年銷售量")
workbook.close()   

效果如下:
在這里插入圖片描述

3)如何向表中插入資料呢?
import xlsxwriter

# 創建一個名為【demo.xlsx】作業簿;
workbook = xlsxwriter.Workbook("demo.xlsx")

# 創建一個名為【2018年銷售量】作業表;
worksheet = workbook.add_worksheet("2018年銷售量")

# 使用write_row方法,為【2018年銷售量】作業表,添加一個表頭;
headings = ['產品','銷量',"單價"] 
worksheet.write_row('A1',headings)
# 使用write方法,在【2018年銷售量】作業表中插入一條資料;
# write語法格式:worksheet.write(行,列,資料) 

data = ["蘋果",500,8.9]
for i in range(len(headings)):
    worksheet.write(1,i,data[i]) 
workbook.close()

效果如下:
在這里插入圖片描述

4. xlrd模塊知識點講解

這里有一個作業簿“test.xlsx”,該檔案中有兩個“Sheet作業表”,分別命名為“2018年銷售量”、“2019年銷售量”,如圖所示,
在這里插入圖片描述

1)如何打開一個“作業簿”?—>open_workbook()
# 這里所說的"打開"并不是實際意義上的打開,只是將該表加載到記憶體中打開,
# 我們并看不到"打開的這個效果"
import xlrd 
file = r"G:\Jupyter\test.xlsx"
xlrd.open_workbook(file)

結果如下:

<xlrd.book.Book at 0x29bb8e4eda0>
2)如何獲取一個作業簿下,所有的“Sheet表”名?—>sheet_names()
import xlrd
file = r"G:\Jupyter\test.xlsx"
fh = xlrd.open_workbook(file)
fh.sheet_names()

結果如下:

['2018年銷售量', '2019年銷售量']
3)如何獲取所有“Sheet表”的物件串列?—>sheets()
import xlrd
file = r"G:\Jupyter\test.xlsx"
fh = xlrd.open_workbook(file)
fh.sheets()

結果如下:

[<xlrd.sheet.Sheet at 0x29bb8f07a90>, <xlrd.sheet.Sheet at 0x29bb8ef1390>]

我們可以利用索引,獲取每一個sheet表的物件,然后可以針對每一個物件,進行操作,

fh.sheets()[0]
<xlrd.sheet.Sheet at 0x29bb8f07a90>
fh.sheets()[1]
<xlrd.sheet.Sheet at 0x29bb8ef1390>
4)如何獲取每個Sheet表的行列數?—>nrows和ncols屬性
import xlrd
file = r"G:\Jupyter\test.xlsx"
fh = xlrd.open_workbook(file)
fh.sheets()
fh.sheets()[0].nrows  # 結果是:4
fh.sheets()[0].ncols  # 結果是:3
fh.sheets()[1].nrows  # 結果是:4
fh.sheets()[1].ncols  # 結果是:3
5)按行獲取,每個Sheet表中的資料—>row_values()
import xlrd
file = r"G:\Jupyter\test.xlsx"
fh = xlrd.open_workbook(file)
sheet1 = fh.sheets()[0]
for row in range(fh.sheets()[0].nrows):
   value = sheet1.row_values(row)
   print(value)

效果如下:
在這里插入圖片描述

三、案例講述

在這里插入圖片描述

1. 將多個Excel表,合并到一個Excel中(每個Excel中只有一個sheet表)

有四張表,圖示中一目了然,就不做過多解釋,
在這里插入圖片描述
實作代碼如下:

import pandas as pd
import os
pwd = "G:\\b"
df_list = []
for path,dirs,files in os.walk(pwd):
    for file in files:
        file_path = os.path.join(path,file)                        
        df = pd.read_excel(file_path) 
        df_list.append(df)
result = pd.concat(df_list)
print(result)
result.to_excel('G:\\b\\result.xlsx',index=False)

結果如下:
在這里插入圖片描述

2. 將多個Excel表,合并到一個Excel中(每個Excel中不只一個sheet表)

有兩個作業簿,如圖所示,一個作業簿是pp.xlsx,一個作業簿是qq.xlsx,作業簿pp.xlsx下,有sheet1和sheet2兩個作業表,作業簿qq.xlsx下,也有sheet1和sheet2兩個作業表,
在這里插入圖片描述
實作代碼如下:

import xlrd
import xlsxwriter
import os

# 打開一個Excel檔案,創建一個作業簿物件
def open_xlsx(file):
    fh=xlrd.open_workbook(file)
    return fh
    
# 獲取sheet表的個數
def get_sheet_num(fh):
    x = len(fh.sheets())
    return x

# 讀取檔案內容并回傳行內容
def get_file_content(file,shnum):
    fh=open_xlsx(file)
    table=fh.sheets()[shnum]
    num=table.nrows
    for row in range(num):
        rdata=table.row_values(row)
        datavalue.append(rdata)
    return datavalue

def get_allxls(pwd):
    allxls = []
    for path,dirs,files in os.walk(pwd):
        for file in files:
            allxls.append(os.path.join(path,file))
    return allxls

# 存盤所有讀取的結果
datavalue = []  
pwd = "G:\\d"                          
for fl in get_allxls(pwd):
    fh = open_xlsx(fl)     
    x = get_sheet_num(fh)  
    for shnum in range(x):
        print("正在讀取檔案:"+str(fl)+"的第"+str(shnum)+"個sheet表的內容...")
        rvalue = get_file_content(fl,shnum)   

# 定義最終合并后生成的新檔案
endfile = "G:\\d\\concat.xlsx"
wb1=xlsxwriter.Workbook(endfile)
# 創建一個sheet作業物件
ws=wb1.add_worksheet()
for a in range(len(rvalue)):
    for b in range(len(rvalue[a])):
        c=rvalue[a][b]
        ws.write(a,b,c)
wb1.close()
print("檔案合并完成")

效果如下:
在這里插入圖片描述

3. 將一個Excel表中的多個sheet表合并,并保存到同一個excel

在這里插入圖片描述
實作代碼如下:

import xlrd
import pandas as pd
from pandas import DataFrame
from openpyxl import load_workbook

excel_name = r"D:\pp.xlsx"
wb = xlrd.open_workbook(excel_name)
sheets = wb.sheet_names()

alldata = DataFrame()
for i in range(len(sheets)):
    df = pd.read_excel(excel_name, sheet_name=i, index=False, encoding='utf8')
    alldata = alldata.append(df)       

writer = pd.ExcelWriter(r"C:\Users\Administrator\Desktop\score.xlsx",engine='openpyxl')
book = load_workbook(writer.path)
writer.book = book  
# 必須要有上面這兩行,假如沒有這兩行,則會刪去其余的sheet表,只保留最終合并的sheet表

alldata.to_excel(excel_writer=writer,sheet_name="ALLDATA")
writer.save()
writer.close()

效果如下:
在這里插入圖片描述

4. 將一個Excel表,按某一列拆分成多張表

在這里插入圖片描述
實作代碼如下:

import pandas as pd
import xlsxwriter
data=pd.read_excel(r"C:\Users\Administrator\Desktop\chaifen.xlsx",encoding='gbk')

area_list=list(set(data['店鋪']))

writer=pd.ExcelWriter(r"C:\Users\Administrator\Desktop\拆好的表1.xlsx",engine='xlsxwriter')
data.to_excel(writer,sheet_name="總表",index=False)

for j in area_list:
    df=data[data['店鋪']==j]
    df.to_excel(writer,sheet_name=j,index=False)

writer.save()  #一定要加上這句代碼,“拆好的表”才會顯示出來

效果如下:
在這里插入圖片描述

轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/191902.html

標籤:其他

上一篇:PyTorch_簡單神經網路搭建_MNIST資料集

下一篇:爬蟲驗證碼的幾種處理方式,已封裝成類,文章末尾有原始碼!

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • vue移動端上拉加載

    可能做得過于簡單或者比較low,請各位大佬留情,一起探討技術 ......

    uj5u.com 2020-09-10 04:38:07 more
  • 優美網站首頁,頂部多層導航

    一個個人用的瀏覽器首頁,可以把一下常用的網站放在這里,平常打開會比較方便。 第一步,HTML代碼 <script src=https://www.cnblogs.com/szharf/p/"js/jquery-3.4.1.min.js"></script> <div id="navigate"> <ul> <li class="labels labels_1"> ......

    uj5u.com 2020-09-10 04:38:47 more
  • 頁面為要加<!DOCTYPE html>

    最近因為寫一個js函式,需要用到$(window).height(); 由于手寫demo的時候,過于自信,其實對前端方面的認識也不夠體系,用文本檔案直接敲出來的html代碼,第一行沒有加上<!DOCTYPE html> 導致了$(window).height();的結果直接是整個document的高 ......

    uj5u.com 2020-09-10 04:38:52 more
  • WordPress網站程式手動升級要做好資料備份

    WordPress博客網站程式在進行升級前,必須要做好網站資料的備份,這個問題良家佐言是遇見過的;在剛開始接觸WordPress博客程式的時候,因為升級問題和博客網站的修改的一些嘗試,良家佐言是吃盡了苦頭。因為購買的是西部數碼的空間和域名,每當佐言把自己的WordPress博客網站搞到一塌糊涂的時候 ......

    uj5u.com 2020-09-10 04:39:30 more
  • WordPress程式不能升級為5.4.2版本的原因

    WordPress是一款個人博客系統,受到英文博客愛好者和中文博客愛好者的追捧,并逐步演化成一款內容管理系統軟體;它是使用PHP語言和MySQL資料庫開發的,用戶可以在支持PHP和MySQL資料庫的服務器上使用自己的博客。每一次WordPress程式的更新,就會牽動無數WordPress愛好者的心, ......

    uj5u.com 2020-09-10 04:39:49 more
  • 使用CSS3的偽元素進行首字母下沉和首行改變樣式

    網頁中常見的一種效果,首字改變樣式或者首行改變樣式,效果如下圖。 代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, ......

    uj5u.com 2020-09-10 04:40:09 more
  • 關于a標簽的講解

    什么是a標簽? <a> 標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。 <a> 元素最重要的屬性是 href 屬性,它指定鏈接的目標。 a標簽的語法格式:<a href=https://www.cnblogs.com/summerxbc/p/"指定要跳轉的目標界面的鏈接">需要展示給用戶看見的內容</a> a標簽 在所有瀏覽器中,鏈接的默認外觀如下: 未被訪問的鏈接帶 ......

    uj5u.com 2020-09-10 04:40:11 more
  • 前端輪播圖

    在需要輪播的頁面是引入swiper.min.js和swiper.min.css swiper.min.js地址: 鏈接:https://pan.baidu.com/s/15Uh516YHa4CV3X-RyjEIWw 提取碼:4aks swiper.min.css地址 鏈接:https://pan.b ......

    uj5u.com 2020-09-10 04:40:13 more
  • 如何設定html中的背景圖片(全屏顯示,且不拉伸)

    1 <style>2 body{background-image:url(https://uploadbeta.com/api/pictures/random/?key=BingEverydayWallpaperPicture); 3 background-size:cover;background ......

    uj5u.com 2020-09-10 04:40:16 more
  • Java學習——HTML詳解(上)

    HTML詳解 初識HTML Hyper Text Markup Language(超文本標記語言) 1 <!--DOCTYPE:告訴瀏覽器我們要使用什么規范--> 2 <!DOCTYPE html> 3 <html lang="en"> 4 <head> 5 <!--meta 描述性的標簽,描述一些 ......

    uj5u.com 2020-09-10 04:40:33 more
最新发布
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 07:59:23 more
  • 生產事故-走近科學之消失的JWT

    入職多年,面對生產環境,盡管都是小心翼翼,慎之又慎,還是難免捅出簍子。輕則滿頭大汗,面紅耳赤。重則系統停擺,損失資金。每一個生產事故的背后,都是寶貴的經驗和教訓,都是專案成員的血淚史。為了更好地防范和遏制今后的各類事故,特開此專題,長期更新和記錄大大小小的各類事故。有些是親身經歷,有些是經人耳傳口授 ......

    uj5u.com 2023-04-18 07:55:04 more
  • 記錄--Canvas實作打飛字游戲

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 打開游戲界面,看到一個畫面簡潔、卻又富有挑戰性的游戲。螢屏上,有一個白色的矩形框,里面不斷下落著各種單詞,而我需要迅速地輸入這些單詞。如果我輸入的單詞與螢屏上的單詞匹配,那么我就可以獲得得分;如果我輸入的單詞錯誤或者時間過長,那么我就會輸 ......

    uj5u.com 2023-04-04 08:35:30 more
  • 了解 HTTP 看這一篇就夠

    在學習網路之前,了解它的歷史能夠幫助我們明白為何它會發展為如今這個樣子,引發探究網路的興趣。下面的這張圖片就展示了“互聯網”誕生至今的發展歷程。 ......

    uj5u.com 2023-03-16 11:00:15 more
  • 藍牙-低功耗中心設備

    //11.開啟藍牙配接器 openBluetoothAdapter //21.開始搜索藍牙設備 startBluetoothDevicesDiscovery //31.開啟監聽搜索藍牙設備 onBluetoothDeviceFound //30.停止監聽搜索藍牙設備 offBluetoothDevi ......

    uj5u.com 2023-03-15 09:06:45 more
  • canvas畫板(滑鼠和觸摸)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canves</title> <style> #canvas { cursor:url(../images/pen.png),crosshair; } #canvasdiv{ bo ......

    uj5u.com 2023-02-15 08:56:31 more
  • 手機端H5 實作自定義拍照界面

    手機端 H5 實作自定義拍照界面也可以使用 MediaDevices API 和 <video> 標簽來實作,和在桌面端做法基本一致。 首先,使用 MediaDevices.getUserMedia() 方法獲取攝像頭媒體流,并將其傳遞給 <video> 標簽進行渲染。 接著,使用 HTML 的 < ......

    uj5u.com 2023-01-12 07:58:22 more
  • 記錄--短視頻滑動播放在 H5 下的實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 短視頻已經無數不在了,但是主體還是使用 app 來承載的。本文講述 H5 如何實作 app 的視頻滑動體驗。 無聲勝有聲,一圖頂百辯,且看下圖: 網址鏈接(需在微信或者手Q中瀏覽) 從上圖可以看到,我們主要實作的功能也是本文要講解的有: ......

    uj5u.com 2023-01-04 07:29:05 more
  • 一文讀懂 HTTP/1 HTTP/2 HTTP/3

    從 1989 年萬維網(www)誕生,HTTP(HyperText Transfer Protocol)經歷了眾多版本迭代,WebSocket 也在期間萌芽。1991 年 HTTP0.9 被發明。1996 年出現了 HTTP1.0。2015 年 HTTP2 正式發布。2020 年 HTTP3 或能正... ......

    uj5u.com 2022-12-24 06:56:02 more
  • 【HTML基礎篇002】HTML之form表單超詳解

    ??一、form表單是什么

    ??二、form表單的屬性

    ??三、input中的各種Type屬性值

    ??四、標簽 ......

    uj5u.com 2022-12-18 07:17:06 more