我是靠谱客的博主 单薄斑马,最近开发中收集的这篇文章主要介绍python连接postgresql数据库及操作,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

python连接postgresql数据库及操作

    • 1.python连接数据库
      • 1.1 安装相关库
      • 1.1 创建连接
      • 1.1 关闭连接
    • 2.python postgresql创建表
      • 2.1 创建连接
      • 2.2 创建事务提交函数
      • 2.3 创建表语句并调用函数
      • 2.4 关闭连接
    • 3.python postgresql批量插入表数据
      • 3.1 创建连接
      • 3.2 创建插入表数据函数
      • 3.3 读取表数据,调用函数
      • 3.4 关闭连接

1.python连接数据库

1.1 安装相关库

pip install psycopg2
pip install pandas

1.1 创建连接

import psycopg2
import pandas as pd
conn = psycopg2.connect(database="postgres", user="postgres", password="", host="127.0.0.1", port="5432", client_encoding='utf-8')
cursor = conn.cursor()

1.1 关闭连接

cursor.close()
conn.close()

2.python postgresql创建表

2.1 创建连接

import psycopg2
import pandas as pd
conn = psycopg2.connect(database="mapdb", user="postgres", password="", host="127.0.0.1", port="5432", client_encoding='utf-8')
cursor = conn.cursor()

2.2 创建事务提交函数

def func_conn(conn,cursor,sql):
try:
cursor.execute(sql)
conn.commit()
print("successfully")
except Exception as e:
print('error',e)
conn.rollback()

2.3 创建表语句并调用函数

sql= """CREATE TABLE climate
(ID INT PRIMARY KEY NOT NULL,
date date NOT NULL
);"""
func_conn(conn,cursor,sql)

2.4 关闭连接

cursor.close()
conn.close()

3.python postgresql批量插入表数据

3.1 创建连接

import psycopg2
import pandas as pd
from io import StringIO
conn = psycopg2.connect(database="mapdb", user="postgres", password="", host="127.0.0.1", port="5432", client_encoding='utf-8')
cursor = conn.cursor()

3.2 创建插入表数据函数

conn = psycopg2.connect(host='127.0.0.1', user="postgres", password="", database="mapdb")
cur = conn.cursor()
def insert_table(data,table_name):
try:
f = StringIO()
data.to_csv(f, sep='t', index=False, header=False)
f.seek(0)
cur.copy_from(f,table_name,columns=data.columns.to_list()) # 将内存对象f中的数据写入数据库,参数columns为所有列的元组
conn.commit()
f.close()
print('成功写入数据库')
except Exception as e:
print(e)
conn.rollback()
f.close()

3.3 读取表数据,调用函数

# 注意:插入数据时,数据库中需要存在这张表
data=pd.read_csv('data/data.csv')
insert_table(data,'table_name')

3.4 关闭连接

cursor.close()
conn.close()

最后

以上就是单薄斑马为你收集整理的python连接postgresql数据库及操作的全部内容,希望文章能够帮你解决python连接postgresql数据库及操作所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(72)

评论列表共有 0 条评论

立即
投稿
返回
顶部