利用Python提取将Excel/PDF文件数据

使用Python来创建一个接口,用于接收Excel文件资源链接,下载文件并执行指定的操作,然后返回处理后的数据。以下是一个基本的示例,展示如何使用Flask来创建这样的接口。请注意,这是一个简化的示例,您可能需要根据实际需求扩展和完善代码。

首先,确保安装Flask:

复制代码
pip install Flask

然后,创建一个Python脚本,比如excel_api.py

复制代码
import os
from flask import Flask, request, jsonify
import requests
import openpyxl

app = Flask(__name)

@app.route("/process_excel", methods=["POST"])
def process_excel():
    try:
        # 获取POST请求中的JSON数据
        data = request.get_json()

        # 从JSON数据中获取Excel文件链接
        excel_url = data.get("excel_url")

        # 下载Excel文件
        excel_response = requests.get(excel_url)
        with open("temp.xlsx", "wb") as f:
            f.write(excel_response.content)

        # 打开Excel文件
        wb = openpyxl.load_workbook("temp.xlsx")

        # 用于存储处理后的数据
        processed_data = {}

        # 处理每个sheet
        for sheet_name in wb.sheetnames:
            sheet = wb[sheet_name]
            sheet_data = []

            # 读取每个单元格的数据
            for row in sheet.iter_rows(values_only=True):
                sheet_data.append(row)

            processed_data[sheet_name] = sheet_data

        # 处理完成后,可以根据需要将数据存储到指定路径

        # 返回处理后的数据
        return jsonify(processed_data)

    except Exception as e:
        return jsonify({"error": str(e)})

if __name__ == "__main__":
    app.run(debug=True)

提取各sheet内单元格(部分为合并单元格)内字段数据

python 复制代码
import openpyxl

def extract_data_from_sheet(sheet):
    data = []
    for row in sheet.iter_rows(values_only=True):
        row_data = []
        for cell in row:
            if cell.data_type == 's':  # 处理合并单元格
                value = sheet.cell(row=cell.row, column=cell.column)._value
            else:
                value = cell.value
            row_data.append(value)
        data.append(row_data)
    return data

# 打开Excel文件
wb = openpyxl.load_workbook("your_excel_file.xlsx")

# 处理每个sheet
for sheet_name in wb.sheetnames:
    sheet = wb[sheet_name]
    sheet_data = extract_data_from_sheet(sheet)
    
    # 在这里,sheet_data 包含了从当前sheet中提取的数据
    print(f"Data from {sheet_name}:")
    for row in sheet_data:
        print(row)
相关推荐
Python图像识别13 分钟前
71_基于深度学习的布料瑕疵检测识别系统(yolo11、yolov8、yolov5+UI界面+Python项目源码+模型+标注好的数据集)
python·深度学习·yolo
千码君20161 小时前
React Native:从react的解构看编程众多语言中的解构
java·javascript·python·react native·react.js·解包·解构
淮北4942 小时前
windows安装minicoda
windows·python·conda
爱喝白开水a3 小时前
LangChain 基础系列之 Prompt 工程详解:从设计原理到实战模板_langchain prompt
开发语言·数据库·人工智能·python·langchain·prompt·知识图谱
默默coding的程序猿5 小时前
3.git的分支携带问题是什么?怎么解决?
java·git·python·svn·gitee·github·intellij-idea
新子y6 小时前
【小白笔记】PyTorch 和 Python 基础的这些问题
pytorch·笔记·python
我是李武涯7 小时前
PyTorch DataLoader 高级用法
人工智能·pytorch·python
Lynnxiaowen7 小时前
今天我们开始学习python语句和模块
linux·运维·开发语言·python·学习
2501_929382657 小时前
MobiOffice解锁高级功能版 v15.9.57971 安卓手机doc, docx ppt, .pptx pdf办公软件
智能手机·pdf·powerpoint·wps
ThreeAu.7 小时前
pytest 实战:用例管理、插件技巧、断言详解
python·单元测试·pytest·测试开发工程师