真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Python中怎么使用pdfplumber讀取PDF寫入Excel

本篇內(nèi)容介紹了“Python中怎么使用pdfplumber讀取PDF寫入Excel”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序定制開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了麻章免費(fèi)建站歡迎大家使用!

Python中怎么使用pdfplumber讀取PDF寫入Excel

一、Python操作PDF 13大庫(kù)對(duì)比

PDF(Portable Document Format)是一種便攜文檔格式,便于跨操作系統(tǒng)傳播文檔。PDF文檔遵循標(biāo)準(zhǔn)格式,因此存在很多可以操作PDF文檔的工具,Python自然也不例外。

Python操作PDF模塊對(duì)比圖如下:

Python中怎么使用pdfplumber讀取PDF寫入Excel

本文主要介紹pdfplumber專注PDF內(nèi)容提取,例如文本(位置、字體及顏色等)和形狀(矩形、直線、曲線),還有解析表格的功能。

二、pdfplumber模塊

其他幾個(gè) Python 庫(kù)幫助用戶從 PDF 中提取信息。作為一個(gè)廣泛的概述,pdfplumber它通過結(jié)合以下功能將自己與其他 PDF 處理庫(kù)區(qū)分開來:

  • 輕松訪問有關(guān)每個(gè) PDF 對(duì)象的詳細(xì)信息

  • 用于提取文本和表格的更高級(jí)別、可自定義的方法

  • 緊密集成的可視化調(diào)試

  • 其他有用的實(shí)用功能,例如通過裁剪框過濾對(duì)象

1. 安裝

cmd控制臺(tái)輸入:

pip install pdfplumber

導(dǎo)包:

import pdfplumber

案例PDF截圖(兩頁未截全):
Python中怎么使用pdfplumber讀取PDF寫入Excel

2. 加載PDF

讀取PDF代碼:pdfplumber.open("路徑/文件名.pdf", password = "test", laparams = { "line_overlap": 0.7 })

參數(shù)解讀:

  • password :要加載受密碼保護(hù)的 PDF,請(qǐng)傳遞password關(guān)鍵字參數(shù)

  • laparams:要將布局分析參數(shù)設(shè)置為pdfminer.six的布局引擎,請(qǐng)傳遞laparams關(guān)鍵字參數(shù)

案例代碼:

import pdfplumberwith pdfplumber.open("./1.pdf") as pdf:
    print(pdf)
    print(type(pdf))

輸出結(jié)果:

3. pdfplumber.PDF類

pdfplumber.PDF類表示單個(gè) PDF,并具有兩個(gè)主要屬性:

屬性說明
.metadata從PDF的Info中獲取元數(shù)據(jù)鍵 /值對(duì)字典。 通常包括“ CreationDate”,“ ModDate”,“ Producer”等。
.pages返回一個(gè)包含pdfplumber.Page實(shí)例的列表,每一個(gè)實(shí)例代表PDF每一頁的信息

1. 讀取PDF文檔信息(.metadata

import pdfplumberwith pdfplumber.open("./1.pdf") as pdf:
    print(pdf.metadata)

運(yùn)行結(jié)果:

{'Author': 'wangwangyuqing', 'Comments': '', 'Company': '', 'CreationDate': "D:20220330113508+03'35'", 'Creator': 'WPS 文字', 'Keywords': '', 'ModDate': "D:20220330113508+03'35'", 'Producer': '', 'SourceModified': "D:20220330113508+03'35'", 'Subject': '', 'Title': '', 'Trapped': 'False'}

2. 輸出總頁數(shù)

import pdfplumberwith pdfplumber.open("./1.pdf") as pdf:
    print(len(pdf.pages))

運(yùn)行結(jié)果:

2

4. pdfplumber.Page類

pdfplumber.Page類是pdfplumber整個(gè)的核心,大多數(shù)操作都圍繞這個(gè)類進(jìn)行操作,它具有以下幾個(gè)屬性:

屬性說明
.page_number順序頁碼,從1第一頁開始,從第二頁開始2,依此類推。
.width頁面的寬度。
.height頁面的高度。
.objects/.chars/.lines/.rects/.curves/.figures/.images這些屬性中的每一個(gè)都是一個(gè)列表,每個(gè)列表包含一個(gè)字典,用于嵌入頁面上的每個(gè)此類對(duì)象。有關(guān)詳細(xì)信息,請(qǐng)參閱下面的“對(duì)象”。

常用方法如下

方法名說明
.extract_text()用來提頁面中的文本,將頁面的所有字符對(duì)象整理為的那個(gè)字符串
.extract_words()返回的是所有的單詞及其相關(guān)信息
.extract_tables()提取頁面的表格
.to_image() 用于可視化調(diào)試時(shí),返回PageImage類的一個(gè)實(shí)例
.close()默認(rèn)情況下,Page對(duì)象緩存其布局和對(duì)象信息,以避免重新處理它。但是,在解析大型 PDF 時(shí),這些緩存的屬性可能需要大量?jī)?nèi)存。您可以使用此方法刷新緩存并釋放內(nèi)存。

1. 讀取第一頁寬度、高度等信息

import pdfplumberwith pdfplumber.open("./1.pdf") as pdf:
    first_page = pdf.pages[0]  # pdfplumber.Page對(duì)象的第一頁
    # 查看頁碼
    print('頁碼:', first_page.page_number)
    # 查看頁寬
    print('頁寬:', first_page.width)
    # 查看頁高
    print('頁高:', first_page.height)

運(yùn)行結(jié)果:

頁碼: 1頁寬: 595.3頁高: 841.9

2. 讀取文本第一頁

import pdfplumberwith pdfplumber.open("./1.pdf") as pdf:
    first_page = pdf.pages[0]  # pdfplumber.Page對(duì)象的第一頁
    text = first_page.extract_text()
    print(text)

運(yùn)行結(jié)果:

店鋪名 價(jià)格 銷量 地址
小罐茶旗艦店 449 474 安徽
零趣食品旗艦店 6.9 60000 福建
天貓超市 1304 3961 上海
天貓超市 139 25000 上海
天貓超市 930 692 上海
天貓超市 980 495 上海
天貓超市 139 100000 上海
三只松鼠旗艦店 288 25000 安徽
紅小廚旗艦店 698 1767 北京
三只松鼠旗艦店 690 15000 安徽
一統(tǒng)領(lǐng)鮮旗艦店 1098 1580 上海
新大猩食品專營(yíng)9.8 7000 湖南.......艦店
蟹納旗艦店 498 1905 上海
三只松鼠堅(jiān)果at茶 188 35000 安徽
嘉禹滬曉旗艦店 598 1517 上海

3. 讀取表格第一頁

import pdfplumberimport xlwtwith pdfplumber.open("1.pdf") as pdf:
    page_one = pdf.pages[0]  # PDF第一頁
    table_1 = page_one.extract_table()  # 讀取表格數(shù)據(jù)
    # 1. 創(chuàng)建Excel表對(duì)象
    workbook = xlwt.Workbook(encoding='utf8')
    # 2. 新建sheet表
    worksheet = workbook.add_sheet('Sheet1')
    # 3. 自定義列名
    col1 = table_1[0]
    # print(col1)# ['店鋪名', '價(jià)格', '銷量', '地址']
    # 4. 將列屬性元組col寫進(jìn)sheet表單中第一行
    for i in range(0, len(col1)):
        worksheet.write(0, i, col1[i])
    # 5. 將數(shù)據(jù)寫進(jìn)sheet表單中
    for i in range(0, len(table_1[1:])):
        data = table_1[1:][i]
        for j in range(0, len(col1)):
            worksheet.write(i + 1, j, data[j])
    # 6. 保存文件分兩種格式
    workbook.save('test.xls')

運(yùn)行結(jié)果:

Python中怎么使用pdfplumber讀取PDF寫入Excel

三、實(shí)戰(zhàn)操作

1. 提取單個(gè)PDF全部頁數(shù)

測(cè)試代碼:

import pdfplumberimport xlwtwith pdfplumber.open("1.pdf") as pdf:
    # 1. 把所有頁的數(shù)據(jù)存在一個(gè)臨時(shí)列表中
    item = []
    for page in pdf.pages:
        text = page.extract_table()
        for i in text:
            item.append(i)
    # 2. 創(chuàng)建Excel表對(duì)象
    workbook = xlwt.Workbook(encoding='utf8')
    # 3. 新建sheet表
    worksheet = workbook.add_sheet('Sheet1')
    # 4. 自定義列名
    col1 = item[0]
    # print(col1)# ['店鋪名', '價(jià)格', '銷量', '地址']
    # 5. 將列屬性元組col寫進(jìn)sheet表單中第一行
    for i in range(0, len(col1)):
        worksheet.write(0, i, col1[i])
    # 6. 將數(shù)據(jù)寫進(jìn)sheet表單中
    for i in range(0, len(item[1:])):
        data = item[1:][i]
        for j in range(0, len(col1)):
            worksheet.write(i + 1, j, data[j])
    # 7. 保存文件分兩種格式
    workbook.save('test.xls')

運(yùn)行結(jié)果(上面得沒截全):

Python中怎么使用pdfplumber讀取PDF寫入Excel

2. 批量提取多個(gè)PDF文件

Python中怎么使用pdfplumber讀取PDF寫入Excel

測(cè)試代碼:

import pdfplumber
import xlwt
import os

# 一、獲取文件下所有pdf文件路徑
file_dir = r'E:\Python學(xué)習(xí)\pdf文件'
file_list = []
for files in os.walk(file_dir):
    # print(files)
    # ('E:\\Python學(xué)習(xí)\\pdf文件', [],
    #  ['1.pdf', '1的副本.pdf', '1的副本10.pdf', '1的副本11.pdf', '1的副本2.pdf', '1的副本3.pdf', '1的副本4.pdf', '1的副本5.pdf', '1的副本6.pdf',
    #   '1的副本7.pdf', '1的副本8.pdf', '1的副本9.pdf'])
    for file in files[2]:
        # 以. 進(jìn)行分割如果后綴為PDF或pdf就拼接地址存入file_list
        if file.split(".")[1] == 'pdf' or file.split(".")[1] == 'PDF':
            file_list.append(file_dir + '\\' + file)

# 二、存入Excel
# 1. 把所有PDF文件的所有頁的數(shù)據(jù)存在一個(gè)臨時(shí)列表中
item = []
for file_path in file_list:
    with pdfplumber.open(file_path) as pdf:
        for page in pdf.pages:
            text = page.extract_table()
            for i in text:
                item.append(i)

# 2. 創(chuàng)建Excel表對(duì)象
workbook = xlwt.Workbook(encoding='utf8')
# 3. 新建sheet表
worksheet = workbook.add_sheet('Sheet1')
# 4. 自定義列名
col1 = item[0]
# print(col1)# ['店鋪名', '價(jià)格', '銷量', '地址']
# 5. 將列屬性元組col寫進(jìn)sheet表單中第一行
for i in range(0, len(col1)):
    worksheet.write(0, i, col1[i])
# 6. 將數(shù)據(jù)寫進(jìn)sheet表單中
for i in range(0, len(item[1:])):
    data = item[1:][i]
    for j in range(0, len(col1)):
        worksheet.write(i + 1, j, data[j])
# 7. 保存文件分兩種格式
workbook.save('test.xls')

運(yùn)行結(jié)果(12個(gè)文件,一個(gè)文件50行總共600行):

Python中怎么使用pdfplumber讀取PDF寫入Excel

“Python中怎么使用pdfplumber讀取PDF寫入Excel”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!


分享題目:Python中怎么使用pdfplumber讀取PDF寫入Excel
標(biāo)題網(wǎng)址:http://weahome.cn/article/jpdcpi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部