百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

利用Python批量转换企业PDF年报为文本

liuian 2025-06-30 17:56 4 浏览

此前,我们介绍过,如何使用Python解析PDF文件:Python解析提取PDF文件的方法简介

现在,我们要对企业年报PDF文件进行批量转换,提出其中的文本。

转换方法:

直接进行转换,保存成对应的txt文本文件:

import pdfplumber
import os
import time

def pdf_to_txt_pdfplumber(pdf_path):
    starttime = time.time()
    print('开始转换',pdf_path)
    output = pdf_path.split('.')[0] +'.txt'
    with pdfplumber.open(pdf_path) as pdf:
        with open(output, 'w', encoding='utf-8') as txt_file:

            for page in pdf.pages:

                page_text = page.extract_text()
                if page_text:
                    txt_file.write(page_text + '\n')
    print('转换完成,耗时:',time.time()-starttime)

# 获取当前目录下所有的pdf文件
files = [i for i in os.listdir() if '.pdf' in i or '.PDF' in i]

for file in files:
    pdf_to_txt_pdfplumber(file)

这里我用两个PDF文件进行测试输出如下:

一般企业的年报在200-300页左右,可以转换一个文件的耗时还是较长的,此时,目录下生成了对应的txt文件:

一些想法:

  • 转换单个PDF文件的耗时较长,所以如果能够直接获取文本,就可以省去转换这个步骤。这也是为什么之前我提到如果能够获取文本,尽量直接获取文本,实在没有的,再下载PDF进行转换
  • 有一些PDF文件会解析失败,可能是因为这个PDF文件是直接由“图片”转换而成的,并非是直接由“文字”模式情况下输出的。
  • 转换不了的怎么办?当成缺失值处理,在经管的研究中,现在的样本量越来越大,存在缺失值也是正常的情况,但是能够处理的尽量进行处理。
  • 如何更好的管理数据?在这里,我们是将每个年报转换成了txt文件,实际上还是较为分散的。其实可以将他们全部储存到数据库中,在本地,sqlite是一个不错的选择,使用也较为方便。在存储数据库时可以添加一些我们需要的字段,例如企业名称,ID,年份,这样在后续的分析中会更加简单清晰。

关于如何保存到数据库,这里提供当时我的一些做法。

首先:创建数据库,设计好我们需要的字段,例如ID,年份,企业名称等。

import sqlite3

conn = sqlite3.connect('report.db')  # 允许多线程访问
sql = '''
        create table report(id integer primary key autoincrement, 
        company varchar, year varchar ,infos varchar)
    ''' 

cursor = conn.cursor()
cursor.execute(sql)
conn.commit()

以上几行代码就完成了数据库的创建:

在这里,我仅进行示范,就不添加更多字段了。

其次:改写原本的代码,写入数据库即可。

import pdfplumber
import os
import time
import sqlite3

conn = sqlite3.connect('report.db') 

def pdf_to_txt_pdfplumber(pdf_path):

    company = pdf_path.split('-')[0]
    year = ''.join([i for i in pdf_path.split('-')[1] if i.isdigit()])
    starttime = time.time()
    print('开始转换',pdf_path)
    all_page_text = ''
    with pdfplumber.open(pdf_path) as pdf:
        
        for page in pdf.pages:
            page_text = page.extract_text()
            if page_text:
                all_page_text = all_page_text + page_text
        # 写入SQLITE
        sql = '''   insert or replace into report(company,year,infos)
                    values("%s","%s","%s")
                        ''' % (company, year, all_page_text.strip())
        cursor = conn.cursor()
        cursor.execute(sql)
        conn.commit()

    print('写入完成,耗时:',time.time()-starttime)

files = [i for i in os.listdir() if '.pdf' in i or '.PDF' in i]

for file in files:
    pdf_to_txt_pdfplumber(file)
conn.close()

执行结果:

可以看到,保存到数据库中更为简洁,更利于数据的管理和后续数据分析。

由于我们是读取文件目录下的所有PDF进行转换,所以可以将转换完成后的pdf文件移动或者删除,这样即使因为特殊原因需要重新转换的时候,也不会重复转换相同的文件。例如:

import shutil

# 移动到当前目录下done文件下
shutil.move(file_dir + '\/' + file, file_dir + '/done')

相关推荐

【开源推荐】给大家推荐个基于ChatGPT的PHP开发库 openai-php-api

有了这个库大家就可以愉快的使用PHP对接chatGPT的官方接口了,至于对接了官方接口想要做什么就看你自己的啦环境要求PHP7.4或以上composer1.6.5以上支持框架Laravel、Sym...

3个最流行的大模型应用开发框架【LLM】

随着人工智能的能力,特别是大型语言模型(LLM)的不断发展和演变,开发人员正在寻求将AI功能整合到他们的应用程序中。虽然文本完成和摘要等简单任务可以通过直接调用OpenAI或Coher...

都说PHP性能差,但PHP性能真的差吗?

今天本能是想测试一个PDO持久化,会不会带来会话混乱的问题先贴一下PHP代码,代码丑了点,但是坚持能run就行,反正就是做个测试。<?php$dsn='mysql:host=l...

saas介绍和原理 · laravel-独立站-商城SaaS – 湾区梁工

SaaS就是多租户,一个应用可以分给很多用户使用,而应用只需要维护一个。那么应用就需要做好各种资源的隔离(数据库,文件,缓存,队列,后台,命令行等等)。有两种类型的多租户SaaS形式:1,单数据库Sa...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

pip 2(根细胞吸收水借助pip2)

pip-h#-helppipdownload#下载.whl文件,然后是可以安装的UV:Python包管理神器-比pip快100倍安装方法Windows:1powershe...

想买《辐射4》的Pip-Boy特别版?那你可得抓紧点

今年秋天玩家就能够玩到《辐射4(Fallout4)》,而且还可以边玩这款游戏边把真实的Pip-Boy穿戴装置套在手上。最近,这款游戏的Pip-Boy特殊版本已经开放玩家在百思买、沃尔玛以及GameS...

PaddleOCR 介绍及部署(paddleocr 安装)

PaddleOCR是由百度飞桨(PaddlePaddle)团队开发的开源OCR工具包,凭借其高精度、多场景适应性和易用性,成为目前最受欢迎的光学字符识别工具之一。以下是其核心特点与技术亮点:一、...

从需求到技术落地:AI产品经理的技术同理心修炼

在当今快速发展的AI时代,产品经理的角色不再局限于需求收集与规划,还需要深入理解技术实现的边界与成本。本文以UnityML-Agents环境配置与寻路Demo实战为例,探讨AI产品经理如何通过亲身体...

在windows上设置python的环境(windows配置python环境)

上文安装好了python,再具体说下python语言的相关环境。#01关于PythonPython是一个高级别的、边运行边解释的、动态类型的编程语言,以简洁的语法、强大的功能和丰富的资源库而闻名。...

uv——Python开发栈中的高效全能小工具

每天写Python代码的同学,肯定都离不开pip、virtualenv、Poetry等基础工具,但是对这些工具可能是又恨又离不开。那么有什么好的替代呢,虫虫今天就给大家介绍一个替代他们的小工具uv,一...

数据驱动型Python应用开发框架:Taipy

1.介绍Taipy是一个用于构建数据驱动应用的Python框架。它允许开发者快速创建交互式数据应用,支持数据可视化、数据处理和自动化工作流。1.1Taipy核心特性低代码/无代码GUI开发数据...

推荐这几个Python实战项目,瞬间读懂Python!

推荐这几个Python实战项目,瞬间读懂Python!Python这玩意儿,说难不难,说简单吧也不是那么容易。我琢磨着,光看书学理论可不行,得动手写点东西才能真正掌握。今儿个我就给大伙儿推荐几个实战项...

Python项目源码加密部署方案(python源码加密工具)

保护Python代码的几种方式对代码进行混淆以降低源码可读性将py文件编译为二进制pyc文件使用Pyinstaller打包源码为二进制可执行文件使用PyArmor加密脚本将py/py...

史上最全!近万字梳理Python 开发必备的 os 模块(建议收藏)

点赞、收藏、加关注,下次找我不迷路一、开篇本文将带你深入探索os模块的核心功能,通过大量实际案例和代码示例,助你彻底掌握这个Python开发的必备神器。全文近万字,建议收藏后慢慢消化,用的时...