ubuntu上跑python连接pg,报错  ImportError: No module named psycopg2





root@pgproxy1:~# python /home/zxw/PGWriterTest_m.py 

Traceback (most recent call last):

  File "/home/zxw/PGWriterTest_m.py", line 4, in <module>

    import psycopg2

ImportError: No module named psycopg2





例如以下安装:

1

root@pgproxy1:~# apt-cache search psycopg2

python-psycopg2 - Python module for PostgreSQL

python-psycopg2-dbg - Python module for PostgreSQL (debug extension)

python-psycopg2-doc - Python module for PostgreSQL (documentation package)

python3-psycopg2 - Python 3 module for PostgreSQL

python3-psycopg2-dbg - Python 3 module for PostgreSQL (debug extension)





2

root@pgproxy1:~# python -V

Python 2.7.3





3

root@pgproxy1:~# apt-get install -y python-psycopg2 python-psycopg2-doc python-psycopg2-dbg

Reading package lists... Done

Building dependency tree       

Reading state information... Done

...

Processing triggers for libc-bin ...

ldconfig deferred processing now taking place

root@pgproxy1:~#





4

脚本例如以下:

# --encoding:utf-8--

import time

import threading

import psycopg2

import Queue

import datetime

该接口相关能够參考其官网:

http://initd.org/psycopg/

class PGWriterTest(threading.Thread):

    """ 初始化 """

    def __init__(self,connstr):

        self.conn = psycopg2.connect(connstr)

        self.cursor = self.conn.cursor()

        

        self.dbnum  = 4

        self.connArray = []

        self.cursorArray = []

        

        

        for i in range(0,self.dbnum):

            #DB port

            dbidstr = '%02d' % (9900 + i)

            if (i == 0  or i == 2 ):

                dstDB = 'host=ip1 user=dbusername password=pwd dbname=dbname port='+ dbidstr

            else:

                dstDB = 'host=ip2 user=dbusername password=pwd dbname=dbname port='+ dbidstr

            print 'connect ' + dstDB

           

            dstConn =  psycopg2.connect(dstDB)

            self.connArray.append(dstConn)

            dstCursor = dstConn.cursor()

            self.cursorArray.append(dstCursor)

        

        # 执行父类的构造函数

        threading.Thread.__init__(self)





    """ 数据写入数据库 """ 

    def read(self,t_id):

        sql = 'SELECT * from get_cont('+str(t_id)+')' 

        self.cursor.execute(sql)

        datalist = []

        for row in self.cursor.fetchall():

            datalist.append(row)

        return datalist    

    

    """ 数据写入数据库 """ 

    def save(self,t_id,data):

        sql = 'SELECT write_cont((%s,character(255) %s,%d,NOW()::timestamp))'

        params = []

        params.append(t_id)

        params.append(data[1])

        params.append(data[2])

        params.append(data[3])





        #print params

        #取db_ins_id

        db_ins_id = 0

        db_ins_id = t_id % self.dbnum

        try:

            print str(datetime.datetime.now()) + " DB " + str(db_ins_id) + " " +  str( t_id ) + " before insert"

            insert_sql = 'SELECT write_cont((%s,character(255) %s,%d,NOW()::timestamp))'

            self.cursorArray[db_ins_id].execute(insert_sql,params)

            self.cursorArray[db_ins_id].execute("COMMIT")

            print str(datetime.datetime.now()) + " DB " + str(db_ins_id) + " " +  str( t_id ) + " inserted"

            return True





        except Exception,ex:

            print("save error:%s" % str(ex))

            print("save t_id:%s\t" % str(t_id))

            print("error cont:%s" % str(params))

            #self.log.write("error param:%s" % str(params))

            #self.log.write("error t_id:%s" % data.get('t_id',''))

            self.cursorArray[db_ins_id].execute("ROLLBACK")

            return False





            

            #測试读取

            """

            try:

                searchsql = 'select t_id from get_cont('+ str(t_id) + ')'

                self.cursorArray[db_ins_id].execute(searchsql)

                data = self.cursorArray[db_ins_id].fetchone()

                if (data == None  or int(data[0]) != t_id ):

                    print ' insert error for ' +str(db_ins_id) + searchsql

            except Exception,searchex:

                print str(searchex) + ' for  ' + searchsql

            """     

        return True

if __name__ == "__main__":

    pgTest = PGWriterTest('host=ip user=DBUser password=pwd dbname=DBNAme port=9999')

    start_time =  str(datetime.datetime.now())

    for i in range(1,10):

        t_id = 1000 + i;

        print str(datetime.datetime.now()) + " getting "

        rows = pgTest.read(t_id)

        

        print str(datetime.datetime.now()) + " gotten "

        #print rows[0]

        pgTest.save(t_id,rows[0])

    print start_time

print  str(datetime.datetime.now())

-----------------

转载请著明出处:

blog.csdn.net/beiigang

ubuntu上跑python连接pg,报错 ImportError: No module named psycopg2的更多相关文章

  1. 【原创】大叔经验分享(11)python引入模块报错ImportError: No module named pandas numpy

    python应用通常需要一些库,比如numpy.pandas等,安装也很简单,直接通过pip # pip install numpyRequirement already satisfied: num ...

  2. python 安装 reportlab 报错 “ImportError: No module named reportlab.lib”

    reportlab是什么? 是一个处理PDF和画图的python开源库. 初次安装: pip install reportlab 重新安装: pip install --upgrade --force ...

  3. python setup.py install 报错ImportError: No module named setuptools

    学习光荣之路python课程时,使用python setup.py install安装其他模块时,第一次安装某模块成功了.安装另一模块却报错ImportError: No module named s ...

  4. (转)coures包下载和安装 可解决报错ImportError: No module named '_curses'

    原创文章,转载请注明出处. coures curses 库 ( ncurses )提供了控制字符屏幕的独立于终端的方法.curses 是大多数类似于 UNIX 的系统(包括Linux)的标准部分,而且 ...

  5. 【Python】Centos + gunicorn+flask 报错ImportError: No module named request

    今天用Python去下载图片,用到了 urllib.request,这个是python3的方法.python2 使用的是urllib2 遇到了这么个问题后台报错,ImportError: No mod ...

  6. python pip 不能用报错: ImportError: No module named _internal

    使用python pip安装包的时候报错: Traceback (most recent call last): File "/usr/local/bin/pip", line 7 ...

  7. coures包下载和安装 可解决报错ImportError: No module named '_curses'

    http://blog.csdn.net/liyaoqing/article/details/54949253 coures curses 库 ( ncurses )提供了控制字符屏幕的独立于终端的方 ...

  8. 克隆kvm虚拟机报错ImportError: No module named 'requests.packages.urllib3'

    2018-06-21 更新系统造成kvm克隆命令报错 virt-clone -o centos--update-clone -n centos--maven-test -f /var/lib/vmdk ...

  9. Django 运行报错 ImportError: No module named 'PIL'

    importError: No module named pil WIN7 64位系统安装 Python PIL 首先通过easy_install安装 说找不到pil模块. 第二通过去官网找:http ...

随机推荐

  1. CAD设置超链接(网页版)

    超链接(Hyperlink)可以看做是一个“热点”,它可以从当前Web页定义的位置跳转到其他位置. 设置对象动态提示事件回调函数. //设置对象动态提示事件回调函数 function DoInputP ...

  2. 初识Typescript及vscode环境配置

    什么是typescript?为什么要用它? typescript简称ts,是js语法的一个超级,由微软团队维护的 js特点(不足) 弱类型:js中的数据变量没有确定的类型,可以存储对象,可以存储数字, ...

  3. 【转】C语言中access函数

    头文件:unistd.h 功 能: 确定文件或文件夹的访问权限.即,检查某个文件的存取方式,比如说是只读方式.只写方式等.如果指定的存取方式有效,则函数返回0,否则函数返回-1. 用 法: int a ...

  4. Redis 压缩存储的配置

    如题,redis是采用了ziplist 元素在不足一定数量时采用压缩存储 hash: zset: list: 如上图所示: ziplist-entries:最大元素数量(即存储了多少个元素) zipl ...

  5. Python之面向对象方法

    Python之面向对象方法 property的用法: property属于类的封装的范畴 property是一种特殊的属性,访问它时会执行一段功能(函数),然后返回值. 用property的方法,就可 ...

  6. scrapy爬取简书整站文章

    在这里我们使用CrawlSpider爬虫模板, 通过其过滤规则进行抓取, 并将抓取后的结果存入mysql中,下面直接上代码: jianshu_spider.py # -*- coding: utf-8 ...

  7. rbac组件之权限初始化(五)

    当用户登陆后,根据用户的角色要为用户生成对应的权限菜单,此时需要将登陆的用户信息获取且获取角色信息,从数据库中获取菜单以及权限信息,并且存入session中. 1.权限流程 第一次请求的页面是登陆页面 ...

  8. codeforces 407 div1 A题(Functions again)

    codeforces 407 div1 A题(Functions again) Something happened in Uzhlyandia again... There are riots on ...

  9. UVa 210 并行程序模拟(deque)

    题意: 模拟n个程序运行 格式一共有5种:var = constant(赋值):print var(打印):lock:unlock:end, 上述5种语句分别需要t1.t2.t3.t4.t5单位时间 ...

  10. ASP.NET获取客户端IP及MAC地址

    朋友最近问如何获取客户端IP及MAC地址,一直想把这段给整理一下,契机来了:下边分为了C#后台获取的方法和前台Javascript(调用ActiveX)获取的方法,大家如果有好的方法一起讨论撒O(∩_ ...