python读取excel导入数据库

一、环境准备,安装包

python 复制代码
pip install pandas openpyxl sqlalchemy

二、数据准备

三、代码编写

python 复制代码
from sqlalchemy import create_engine
import pandas as pd

class GDPDataImporter:
    def __init__(self, db_type, dbapi, host, port, database, username, password):
        """
        初始化数据库连接参数
        :param db_type: 数据库类型,如 'mysql', 'mssql+pyodbc', 'postgresql' 等
        :param dbapi: 数据库API,如 'pymysql' 对于MySQL
        :param host: 数据库主机地址
        :param port: 数据库端口
        :param database: 数据库名
        :param username: 数据库用户名
        :param password: 数据库密码
        """
        self.engine = create_engine(f"{db_type}+{dbapi}://{username}:{password}@{host}:{port}/{database}")

    def import_data(self, excel_file_path, table_name):
        """
        从Excel文件导入数据到数据库
        :param excel_file_path: Excel文件的路径
        :param table_name: 数据库中的表名
        """
        try:
            # 使用pandas读取Excel文件
            df = pd.read_excel(excel_file_path)
            
            # 将DataFrame数据写入数据库表
            df.to_sql(name=table_name, con=self.engine, if_exists='replace', index=False)
            print("数据导入成功!")
        except Exception as e:
            print(f"数据导入失败: {e}")

# 使用示例
if __name__ == "__main__":
    # 实例化导入器类
    importer = GDPDataImporter(
        db_type='mysql',
        dbapi='pymysql',
        host='localhost',
        port='3306',
        database='world',
        username='root',
        password='123456'
    )
    
    # Excel文件路径
    excel_file_path = r'F:\省会城市总、人均GDP.xlsx'
    # 导入数据到数据库
    importer.import_data(excel_file_path, 'GDP')

四、查看表数据

相关推荐
Yan-英杰21 分钟前
百度搜索和文心智能体接入DeepSeek满血版——AI搜索的新纪元
图像处理·人工智能·python·深度学习·deepseek
weixin_307779131 小时前
Azure上基于OpenAI GPT-4模型验证行政区域数据的设计方案
数据仓库·python·云计算·aws
玩电脑的辣条哥2 小时前
Python如何播放本地音乐并在web页面播放
开发语言·前端·python
多想和从前一样5 小时前
Django 创建表时 “__str__ ”方法的使用
后端·python·django
小喵要摸鱼6 小时前
【Pytorch 库】自定义数据集相关的类
pytorch·python
IT古董6 小时前
【开源向量数据库】Milvus简介
数据库·开源·milvus
刘_sy6 小时前
使用EasyExcel和多线程实现高效数据导出
java·excel·easyexcel·批量导出excel
bdawn7 小时前
深度集成DeepSeek大模型:WebSocket流式聊天实现
python·websocket·openai·api·实时聊天·deepseek大模型·流式输出
Jackson@ML7 小时前
Python数据可视化简介
开发语言·python·数据可视化
mosquito_lover17 小时前
怎么把pyqt界面做的像web一样漂亮
前端·python·pyqt