zoukankan      html  css  js  c++  java
  • python错误处理

    连接数据库时的编码问题

    报错

    python编码错误:UnicodeDecodeError: 'utf8' codec can't decode

    或者UnicodeDecodeError: 'ascii' codec can't decode byte 0xcf in position 7: ordinal not in range(128)

    考虑使用如下方法http://www.jb51.net/article/59297.htm

    代码如下

    #coding:utf-8
    import sys
    reload(sys)
    sys.setdefaultencoding('utf8')
    
    import mysql.connector
    
    cnx =mysql.connector.connect(user='bitbear',password='bittest123',host='101.201.50.1',database='bitbear',charset='utf8')

    参考https://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb493182103fac9270762a000/001391435131816c6a377e100ec4d43b3fc9145f3bb8056000

    #coding:utf-8
    import sys
    reload(sys)
    sys.setdefaultencoding('utf8')
    
    import mysql.connector
    
    conn =mysql.connector.connect(user='bitbear',password='bittest123',host='101.201.50.1',database='bitbear',charset='utf8')
    
    
    cursor = conn.cursor()
    
    cursor.execute('create table usertest (id varchar(20) primary key, name varchar(20))')
    
    cursor.execute('insert into usertest (id, name) values (%s, %s)', ['1', 'Michael'])
    
    cursor.rowcount
    
    conn.commit()
    
    cursor.close()
    View Code

      参考:http://www.cnblogs.com/bigberg/p/6430095.html

    数据库汇总usertest1.py中id字段为自增的情况下,向其中插入json

    #coding:utf-8
    import sys
    reload(sys)
    sys.setdefaultencoding('utf8')
    
    import mysql.connector
    import json
    
    test_dict = {'bigberg': [7600, {1: [['iPhone', 6300], ['Bike', 800], ['shirt', 300]]}]}
    print(test_dict)
    print(type(test_dict))
    
    json_str = json.dumps(test_dict)
    print(json_str)
    print(type(json_str))
    
    #####
    
    conn =mysql.connector.connect(user='bitbear',password='bittest123',host='101.201.50.1',database='bitbear',charset='utf8')
    
    cursor = conn.cursor()
    
    #cursor.execute('create table usertest (id varchar(20) primary key, name varchar(20))')
    
    cursor.execute('insert into usertest1 ( name) values ( %s)', [ json_str])
    
    cursor.rowcount
    
    conn.commit()
    
    cursor.close()
    View Code

      使用本地文件读取,参考:http://blog.csdn.net/dyx404514/article/details/50186413

    将json数据存储在my.json中,打开后存到变量x中,格式为字符串,然后可以直接写到数据库中,代码如下

    #coding:utf-8
    import sys
    reload(sys)
    sys.setdefaultencoding('utf8')
    
    import mysql.connector
    import json as js
    
    #f = file('./my.json')
    #x=js.loads(f)
    #print x
    
    
    with open('./my.json', 'r') as f:
        x=f.read()
        print type(x)
    
    
    #####
    
    conn =mysql.connector.connect(user='bitbear',password='bittest123',host='101.201.50.1',database='bitbear',charset='utf8')
    
    cursor = conn.cursor()
    
    #cursor.execute('create table usertest (id varchar(20) primary key, name varchar(20))')
    
    cursor.execute('insert into usertest1 ( name) values ( %s)', [x])
    
    cursor.rowcount
    
    conn.commit()
    
    cursor.close()
    View Code

    使用pycharm2017+python3.6连接数据库时无法导入mysql以及mysqldb

    mysqldb暂不支持python3.6,使用pymysql

    参考:https://www.cnblogs.com/hank-chen/p/6624299.html

    pycharm激活

    http://blog.csdn.net/mr_hhh/article/details/79062747

  • 相关阅读:
    Job流程:Shuffle详解
    学Python Django学得很迷茫,怎么办?-转自知乎
    URL补充
    创建多对多以及增加示例
    Day20-初识Ajax
    笔记-自己看Day20-待续
    Day20-单表中获取表单数据的3种方式
    Day19内容回顾
    一点疑惑的解释
    python os.path模块常用方法详解
  • 原文地址:https://www.cnblogs.com/vactor/p/7899565.html
Copyright © 2011-2022 走看看