利用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)
相关推荐
databook12 小时前
Manim实现闪光轨迹特效
后端·python·动效
Juchecar13 小时前
解惑:NumPy 中 ndarray.ndim 到底是什么?
python
用户83562907805113 小时前
Python 删除 Excel 工作表中的空白行列
后端·python
Json_13 小时前
使用python-fastApi框架开发一个学校宿舍管理系统-前后端分离项目
后端·python·fastapi
数据智能老司机20 小时前
精通 Python 设计模式——分布式系统模式
python·设计模式·架构
数据智能老司机21 小时前
精通 Python 设计模式——并发与异步模式
python·设计模式·编程语言
数据智能老司机21 小时前
精通 Python 设计模式——测试模式
python·设计模式·架构
数据智能老司机21 小时前
精通 Python 设计模式——性能模式
python·设计模式·架构
c8i21 小时前
drf初步梳理
python·django
每日AI新事件21 小时前
python的异步函数
python