python学习 - Django切换MySQL数据库、json.dumps中的参数详解

准备

软件 版本
Django 2.1.3
Python 3.7.1

默认使用的是sqlite3

DATABASES = {
     'default': {
         'ENGINE': 'django.db.backends.sqlite3',
         'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
     }
}

切换为MySql:

# settings.py
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'book',
        'USER': 'root',
        'PASSWORD': '123456',
        'HOST': '127.0.0.1',
        'POST': '3306',
    }
}

实现步骤:

我们使用Django 来操作MySQL,实际上底层还是通过Python来操作的。因此我们想要用Django来操作MySQL,首先还是需要安装一个驱动程序。在Python3中,驱动程序有多种选择。比如有pymysql以及mysqlclient等。

常见的Mysql驱动介绍:

  • MySQL-python:也就是MySQLdb。是对C语言操作MySQL数据库的一个简单封装。遵循了Python DB API v2。但是只支持Python2,目前还不支持Python3。
  • mysqlclient:是MySQL-python的另外一个分支。支持Python3并且修复了一些bug。
  • pymysql:纯Python实现的一个驱动。因为是纯Python编写的,因此执行效率不如MySQL-python。并且也因为是纯Python编写的,因此可以和Python代码无缝衔接。
  • MySQL Connector/Python:MySQL官方推出的使用纯Python连接MySQL的驱动。因为是纯Python开发的。效率不高。

mysqlclient安装

基于目前的环境以及版本来说,直接运行 pip install mysqlclient 是会报错的,具体错误,自己执行以下就知道了。

解决办法:

去 https://www.lfd.uci.edu/~gohlke/pythonlibs/#mysqlclient 下载指定文件,我用的是python3.7,win环境是64位,所以下载了mysqlclient-1.3.13-cp37-cp37m-win_amd64.whl。

然后执行:

pip3 install mysqlclient-1.3.13-cp37-cp37m-win_amd64.whl

如果出现以下说明安装成功:

Installing collected packages: mysqlclient
Successfully installed mysqlclient-1.3.13

迁移数据库

Django中通过以下命令来迁移数据库,在每次创建Model时,执行该命令,在数据库中生成对应的表:

python manage.py makemigrations
python manage.py migrate

例子如下:

import json
import numpy as np


class MyEncoder(json.JSONEncoder):
    def default(self, obj):
        if isinstance(obj, np.ndarray):
            return obj.tolist()
        elif isinstance(obj, bytes):
            return str(obj, encoding='utf-8');
        return json.JSONEncoder.default(self, obj)


dict = {'id': 1, 'title': b'\xe7\xac\xac\xe4\xb8\x80\xe7\xab\xa0 \xe7\xa7\xa6\xe7\xbe\xbd'}
dup = json.dumps(dict, cls=MyEncoder, ensure_ascii=False, indent=4)
print(dup)

indent

根据数据格式缩进显示,读起来更加清晰,indent的数值,代表缩进的位数。

ensure_ascii

如果无任何配置,或者说使用默认配置, 输出的会是中文的ASCII字符吗,而不是真正的中文。 这是因为json.dumps 序列化时对中文默认使用的ascii编码。

{
    "id": 1,
    "title": "\u7b2c\u4e00\u7ae0 \u79e6\u7fbd"
}

cls

dict类型的数据(存在中文),在python2中是可以转化的,但是在python3中存在序列化问题:

TypeError: Object of type bytes is not JSON serializable

编码中遇到的一些问题

中文编码问题

这样一段代码:

import json
dict = {'id': 1, 'title': b'\xe7\xac\xac\xe4\xb8\x80\xe7\xab\xa0 \xe7\xa7\xa6\xe7\xbe\xbd'}
dup = json.dumps(dict ,ensure_ascii=False)
print(dup)

Python2执行输出:

{"id": 1, "title": "第一章 秦羽"}

Python3执行报错:

TypeError: Object of type bytes is not JSON serializable

终稿:

安装模块:

pip3 install numpy

最终代码:

import json
import numpy as np


class MyEncoder(json.JSONEncoder):
    def default(self, obj):
        if isinstance(obj, np.ndarray):
            return obj.tolist()
        elif isinstance(obj, bytes):
            return str(obj, encoding='utf-8');
        return json.JSONEncoder.default(self, obj)

dict  = {'id': 1, 'title': b'\xe7\xac\xac\xe4\xb8\x80\xe7\xab\xa0 \xe7\xa7\xa6\xe7\xbe\xbd'}
dup = json.dumps(dict , cls=MyEncoder, ensure_ascii=False, indent=4)
print(dup)

之前的单个转码:

sql = "SELECT id,title FROM novel LIMIT 10;"
result = mysql.getAll(sql)
for each in result:
    ach['title'] = each['title'].decode('utf-8')

Web输出

JSON (JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于ECMAScript的一个子集。

Python3 中可以使用 json 模块来对 JSON 数据进行编解码,它包含了两个函数:

  • json.dumps(): 对数据进行编码。
  • json.loads(): 对数据进行解码。
# 字典类型中有中文编码
dict= {'id': 1, 'title': b'\xe7\xac\xac\xe4\xb8\x80\xe7\xab\xa0 \xe7\xa7\xa6\xe7\xbe\xbd'}
# 转Json对象
dict= json.dumps(dict, cls=MyEncoder, ensure_ascii=False, indent=4)
# 转字典类型
dict= json.loads(dict)

context = {}
context.update({'novel_list': result})
# 或者直接
context = {'novel_list': result}

return render(request, 'novel_list.html',  context)

相关推荐

  1. python-0008-修改django数据库mysql

    2024-06-09 08:12:01       20 阅读
  2. MySQLSET数据类型详解

    2024-06-09 08:12:01       31 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-09 08:12:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-09 08:12:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-09 08:12:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-09 08:12:01       18 阅读

热门阅读

  1. C++常用标准库函数(长期更新中)

    2024-06-09 08:12:01       7 阅读
  2. 在 ASP.NET Core 中实现速率限制中间件

    2024-06-09 08:12:01       10 阅读
  3. 一些JVM面试题

    2024-06-09 08:12:01       10 阅读
  4. C++的std::optional的用法

    2024-06-09 08:12:01       6 阅读
  5. OCP学习笔记-007 SQL语言之三:DDL

    2024-06-09 08:12:01       11 阅读
  6. 跨网段路由

    2024-06-09 08:12:01       9 阅读
  7. Redisson知识

    2024-06-09 08:12:01       10 阅读
  8. Linux进程基本概念

    2024-06-09 08:12:01       11 阅读
  9. 2024-06-08 问AI: 大语言模型中,思维链CoT是什么?

    2024-06-09 08:12:01       11 阅读
  10. 自然语言处理(NLP)—— 符号方法与符号语言

    2024-06-09 08:12:01       5 阅读
  11. git凭证

    git凭证

    2024-06-09 08:12:01      7 阅读
  12. Sass 使用指南:让 CSS 编程更高效、更强大

    2024-06-09 08:12:01       9 阅读
  13. AI学习指南机器学习篇-使用C4.5算法构建决策树

    2024-06-09 08:12:01       9 阅读