欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

教你用Python實(shí)現(xiàn)Excel表格處理

 更新時(shí)間:2021年05月19日 08:57:51   作者:董可倫  
今天教各位小伙伴怎么用Python處理excel,文中有非常詳細(xì)的代碼示例及相關(guān)知識總結(jié),對正在學(xué)習(xí)python的小伙伴們很有幫助,需要的朋友可以參考下

一、文件

一個(gè)測試有兩個(gè)sheet頁的Excel測試文件 test.xlsx

二、代碼

import pandas as pd

file1 = pd.ExcelFile('D:\\data\\py\\test.xlsx')
file2 = pd.read_excel('D:\\data\\py\\test.xlsx')
print(file)
<pandas.io.excel._base.ExcelFile object at 0x0000021DE525DF88>
-----------------分割線---------------------
   姓名  年齡 性別  住址
0  張三   7  男 NaN
1  李四   6  男 NaN
2  王芳   6  女 NaN

三、分析

pd.read_excel讀出來是一個(gè)dataframe可以直接打印出內(nèi)容,但是只能讀取一個(gè)sheet頁,默認(rèn)第一個(gè)sheet頁

@Appender(_read_excel_doc)
@deprecate_kwarg("skip_footer", "skipfooter")
def read_excel(
    io,
    sheet_name=0,
    header=0,
    names=None,
    index_col=None,
    usecols=None,
    squeeze=False,
    dtype=None,
    engine=None,
    converters=None,
    true_values=None,
    false_values=None,
    skiprows=None,
    nrows=None,
    na_values=None,
    keep_default_na=True,
    verbose=False,
    parse_dates=False,
    date_parser=None,
    thousands=None,
    comment=None,
    skip_footer=0,
    skipfooter=0,
    convert_float=True,
    mangle_dupe_cols=True,
    **kwds
):

    for arg in ("sheet", "sheetname", "parse_cols"):
        if arg in kwds:
            raise TypeError(
                "read_excel() got an unexpected keyword argument " "`{}`".format(arg)
            )

    if not isinstance(io, ExcelFile):
        io = ExcelFile(io, engine=engine)
    elif engine and engine != io.engine:
        raise ValueError(
            "Engine should not be specified when passing "
            "an ExcelFile - ExcelFile already has the engine set"
        )

    return io.parse(
        sheet_name=sheet_name,
        header=header,
        names=names,
        index_col=index_col,
        usecols=usecols,
        squeeze=squeeze,
        dtype=dtype,
        converters=converters,
        true_values=true_values,
        false_values=false_values,
        skiprows=skiprows,
        nrows=nrows,
        na_values=na_values,
        keep_default_na=keep_default_na,
        verbose=verbose,
        parse_dates=parse_dates,
        date_parser=date_parser,
        thousands=thousands,
        comment=comment,
        skipfooter=skipfooter,
        convert_float=convert_float,
        mangle_dupe_cols=mangle_dupe_cols,
        **kwds
    )

pd.ExcelFile 返回值是一個(gè)Excel對象,不能直接用,但是可以讀取整個(gè)Excel內(nèi)容

四、pd.ExcelFile

file = pd.ExcelFile('D:\\data\\py\\test.xlsx')

sheet頁名稱

print(file.sheet_names)
['一年級', '二年級']

遍歷讀取每個(gè)sheet頁的內(nèi)容

for name in file.sheet_names:
    _df = pd.read_excel(file,name)
    print(_df)
  姓名  年齡 性別  住址
0  張三   7  男 NaN
1  李四   6  男 NaN
2  王芳   6  女 NaN
   姓名  年齡 性別
0  李明   8  男
1  劉敏   8  女
2  張強(qiáng)   7  男

將兩個(gè)sheet頁的內(nèi)容合并,并添加一列內(nèi)容為sheet頁名稱

df_list=[]
for name in file.sheet_names:
    _df = pd.read_excel(file,name)
    _df['班級']=name
    df_list.append(_df)
df = pd.concat([_df for _df in df_list],sort=False)
print(df)
姓名  年齡 性別  住址   班級
0  張三   7  男 NaN  一年級
1  李四   6  男 NaN  一年級
2  王芳   6  女 NaN  一年級
0  李明   8  男 NaN  二年級
1  劉敏   8  女 NaN  二年級
2  張強(qiáng)   7  男 NaN  二年級

忽略掉原來的index

df = pd.concat([_df for _df in df_list],ignore_index=True,sort=False)
print(df)
姓名  年齡 性別  住址   班級
0  張三   7  男 NaN  一年級
1  李四   6  男 NaN  一年級
2  王芳   6  女 NaN  一年級
3  李明   8  男 NaN  二年級
4  劉敏   8  女 NaN  二年級
5  張強(qiáng)   7  男 NaN  二年級

修改列名為英文

df = df.rename(columns={'姓名': 'name', '年齡': 'age', '性別': 'sex', '住址': 'address', '班級': 'class'})
print(df)
name  age sex  address class
0   張三    7   男      NaN   一年級
1   李四    6   男      NaN   一年級
2   王芳    6   女      NaN   一年級
3   李明    8   男      NaN   二年級
4   劉敏    8   女      NaN   二年級
5   張強(qiáng)    7   男      NaN   二年級

將df保存為CSV、Excel文件

df.to_csv('../data/sheet合并.csv',index=False) 
df.to_excel('../data/sheet合并.xls',index=True) 

五、總結(jié)

可以發(fā)現(xiàn)Python讀寫Excel文件還是很方便的!

/python/blob/master/data/sheet%E5%90%88%E5%B9%B6.xls)

df.to_csv('../data/sheet合并.csv',index=False) 
df.to_excel('../data/sheet合并.xls',index=True) 

到此這篇關(guān)于教你用Python實(shí)現(xiàn)Excel表格處理的文章就介紹到這了,更多相關(guān)Python處理Excel內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 通過LyScript實(shí)現(xiàn)從文本中讀寫ShellCode

    通過LyScript實(shí)現(xiàn)從文本中讀寫ShellCode

    LyScript 插件通過配合內(nèi)存讀寫,可實(shí)現(xiàn)對特定位置的ShellCode代碼的導(dǎo)出。本文將利用這一特性實(shí)現(xiàn)從文本中讀寫ShellCode,感興趣的可以了解一下
    2022-08-08
  • python實(shí)現(xiàn)對文件進(jìn)行MD5校驗(yàn)

    python實(shí)現(xiàn)對文件進(jìn)行MD5校驗(yàn)

    這篇文章主要為大家詳細(xì)介紹了如何使用python對文件進(jìn)行MD5校驗(yàn)并比對文件重復(fù),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-01-01
  • Python OrderedDict字典排序方法詳解

    Python OrderedDict字典排序方法詳解

    這篇文章主要介紹了Python OrderedDict字典使用方法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-05-05
  • python實(shí)現(xiàn)數(shù)組平移K位問題

    python實(shí)現(xiàn)數(shù)組平移K位問題

    這篇文章主要介紹了python實(shí)現(xiàn)數(shù)組平移K位問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • 通過Python 接口使用OpenCV的方法

    通過Python 接口使用OpenCV的方法

    下面小編就為大家分享一篇通過Python 接口使用OpenCV的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • Python區(qū)塊鏈Creating?Miners教程

    Python區(qū)塊鏈Creating?Miners教程

    這篇文章主要為大家介紹了Python區(qū)塊鏈Creating?Miners教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • Python之關(guān)于類變量的兩種賦值區(qū)別詳解

    Python之關(guān)于類變量的兩種賦值區(qū)別詳解

    這篇文章主要介紹了Python之關(guān)于類變量的兩種賦值區(qū)別詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • Django用戶認(rèn)證系統(tǒng) User對象解析

    Django用戶認(rèn)證系統(tǒng) User對象解析

    這篇文章主要介紹了Django用戶認(rèn)證系統(tǒng) User對象解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • Python中的map、reduce和filter淺析

    Python中的map、reduce和filter淺析

    這篇文章主要介紹了Python中的map、reduce和filter,用實(shí)例來理解這3個(gè)函數(shù),需要的朋友可以參考下
    2014-04-04
  • Python基礎(chǔ)詳解之郵件處理

    Python基礎(chǔ)詳解之郵件處理

    這篇文章主要介紹了Python基礎(chǔ)詳解之郵件處理,文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)python基礎(chǔ)的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04

最新評論