sha*_*fri 4 python sql psycopg2
有没有办法提供像Quoted分隔符
import psycopg2
f_cm = open('cm.sql', 'r')
constr = "dbname='mydb' user= 'pgsql' host='127.0.0.1'"
db = psycopg2.connect(constr)
st = db.cursor()
#st.copy_from(f_cm, 'mytable', sep='","', columns = ('col1','col2', 'col3'))
#instead of
st.copy_from(f_cm, 'mytable', sep=',', columns = ('col1','col2', 'col3'))
Run Code Online (Sandbox Code Playgroud)
日期格式为:
"54654","4454","45465"
"54546","4545","885dds45"
"54536","4546","885dd45"
Run Code Online (Sandbox Code Playgroud)
我在psycopg2.0.9中搜索并发现psycopg New的好消息
转到标题psycopg 2.0.9中的新功能,其中指出:copy_from()和copy_to()现在可以使用带引号的分隔符.
工具:
psycopg2 = 2.4.5
python = 2.7.3
Run Code Online (Sandbox Code Playgroud)
看起来像cursor.copy_from或copy_to不支持引用表.解决方案是使用copy_expert.
import psycopg2
f_cm = open('cm.sql', 'r')
constr = "dbname='mydb' user= 'pgsql' host='127.0.0.1'"
db = psycopg2.connect(constr)
st = db.cursor()
copy = "COPY mytable(col1,col2, col3) FROM STDIN with csv"
st.copy_expert(sql=copy, file=f_cm)
db.commit()
st.close()
db.close()
Run Code Online (Sandbox Code Playgroud)