Python 用pandas连接Postgresql库

pandas确实蛮强的,记录使用的代码

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

# 从环境变量中读取数据库连接信息
user = os.getenv('DB_USER', 'xxx')              # 数据库用户名
password = os.getenv('DB_PASSWORD', 'xxx')      # 数据库密码
host = os.getenv('DB_HOST', '192.168.0.1')      # 数据库主机地址
port = os.getenv('DB_PORT', '5432')             # 数据库端口
dbname = os.getenv('DB_NAME', 'xxx')            # 数据库名称

# 创建数据库引擎
# 这个引擎将用于与 PostgreSQL 数据库建立连接
engine = create_engine(f'postgresql://{user}:{password}@{host}:{port}/{dbname}')

# 插入数据到数据库
def insert_data(df):
    """
    将 DataFrame 插入到数据库表中。

    参数:
    df (pd.DataFrame): 要插入的 DataFrame 数据
    """
    df.to_sql(name='employees', 
              schema='xxx',        # 库名
              con=engine, 
              if_exists='append',  # 追加数据到现有表
              index=False)         # 不写入 DataFrame 的索引列

# 查询数据库中的数据
def query_data():
    """
    从数据库中查询数据并返回 DataFrame。

    返回:
    pd.DataFrame: 查询结果 DataFrame
    """
    query = "SELECT * FROM xxx.employees"
    return pd.read_sql_query(query, con=engine)

# 主程序
if __name__ == '__main__':
    # 创建一个 DataFrame,包含要插入的新数据
    df = pd.DataFrame({
        'id': [14, 25, 36],                 # ID 列
        'name': ['Alice', 'Bob', 'Charlie'], # 名字列
        'age': [25, 30, 35],                # 年龄列
        'department': ['HR', 'Engineering', 'Marketing']  # 部门列
    })

    # 将数据插入到数据库中
    insert_data(df)
    
    # 查询并打印数据库中的数据
    df_result = query_data()
    print(df_result)
相关推荐
SiYuanFeng6 小时前
Colab复现 NanoChat:从 Tokenizer(CPU)、Base Train(CPU) 到 SFT(GPU) 的完整踩坑实录
python·colab
炸炸鱼.7 小时前
Python 操作 MySQL 数据库
android·数据库·python·adb
_深海凉_7 小时前
LeetCode热题100-颜色分类
python·算法·leetcode
AC赳赳老秦8 小时前
OpenClaw email技能:批量发送邮件、自动回复,高效处理工作邮件
运维·人工智能·python·django·自动化·deepseek·openclaw
zhaoshuzhaoshu8 小时前
Python 语法之数据结构详细解析
python
AI问答工程师8 小时前
Meta Muse Spark 的"思维压缩"到底是什么?我用 Python 复现了核心思路(附代码)
人工智能·python
zfan5209 小时前
python对Excel数据处理(1)
python·excel·pandas
小饕9 小时前
我从零搭建 RAG 学到的 10 件事
python
老歌老听老掉牙9 小时前
PyQt5+Qt Designer实战:可视化设计智能参数配置界面,告别手动布局时代!
python·qt
格鸰爱童话10 小时前
向AI学习项目技能(六)
java·人工智能·spring boot·python·学习