用python导入20个G的json数据到Mysql数据库
整体思路参考资料:https://blog.csdn.net/layman2016/article/details/79252499
作业:有一个16个G的跟疫情相关的json新闻大数据(article.txt),用python3将导入到数据库Mysql5.7,然后用可视化工具(我用的是R)对这些数据进行可视化
提供了数据字典,对字段有详细的说明
还有一个article_demo.csv
说明:1.由于json数据太大,需要用json.loads()一条一条的解析,然后再插入到Mysql数据库中
2.数据量大,导入Mysql数据库速度太慢,一开始导了一遍需要4个小时+,经过调整mysql的my.ini参数设置时间缩为10分钟左右
3.当然也可以导出到csv,然后进行可视化也行,但是不利于后续对数据的操作,导出导入等。所以选择导入到数据库,方便练习简单的sql操作;当然导入到数据库会出现很多细节问题,对于新手也是一个练习的机会
结果:最终导入成功40万+条数据,舍弃了因清洗问题和其他报错问题的5万+条数据,基本满足可以完成作业的要求。
全部代码如下:(整体思路跟layman2016一致)
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import jsonimport pymysql #创建表格
def prem(db):
cursor = db.cursor() #调用操作游标
cursor.execute("SELECT VERSION()") #使用exectue执行SQL语句
data = cursor.fetchone() #使用fetchone获取一条数据
print("Database version : %s " % data) # 结果表明已经连接成功
cursor.execute("DROP TABLE IF EXISTS article") # 检查一下有没有同名,有则删除
#19个字段
sql = """CREATE TABLE article (
content varchar(8000),title varchar(100),appName varchar(20),
catLabel2 varchar(50),sourceRegion varchar(50),copyDate varchar(20),spamLabel varchar(40),
appCode varchar(50),spamCode int,sourceType varchar(50),sentimentDistTitle_confidence float(8,6),
sentimentDistTitle_positive float(8,6),sentimentDistTitle_negative float(8,6),
id varchar(100), sentimentDist_confidence float(8,6),sentimentDist_positive float(8,6),sentimentDist_negative float(8,6),
publishDate varchar(20),url varchar(1000)
)ENGINE=MyISAM default charset=utf8""" #更换引擎,提高插入速度 cursor.execute(sql) # 根据需要创建一个表格 def article_insert(db):
with open('E:/json_article/article.txt', encoding='utf-8') as f:
i = 0
error = 0
line = f.readline() # 使用逐行读取的方法
while line:
i += 1
if i%10000==0:
print("count is ",i)
try:
line = f.readline()
article_text = json.loads(c,strict=False) # 解析每一行数据,strict防止Invalid control character
#print(c) #19个
insert_re = "insert into article(content,title,appName,catLabel2,sourceRegion,copyDate,spamLabel,appCode,spamCode,sourceType,sentimentDistTitle_confidence,sentimentDistTitle_positive,sentimentDistTitle_negative,id,sentimentDist_confidence,sentimentDist_positive,sentimentDist_negative,publishDate,url) values (%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)" result = []
result.append((article_text["content"],article_text["title"],article_text["appName"],
article_text["catLabel2"], article_text["sourceRegion"],article_text["copyDate"],article_text["spamLabel"],
article_text["appCode"],article_text["spamCode"],article_text["sourceType"],
article_text['sentimentDistTitle']['confidence'],article_text['sentimentDistTitle']['positive'],article_text['sentimentDistTitle']['negative'],
article_text['id'],article_text['sentimentDist']['confidence'],article_text['sentimentDist']['positive'],
article_text['sentimentDist']['negative'], article_text['publishDate'],article_text["url"]))
#print(result)
#print(type(result)) cursor = db.cursor()
cursor.executemany(insert_re,result) db.commit() except Exception as e:
error = error+1
#print(str(e))
continue
except UnicodeDecodeError as e:
error = error+1 #解决,直接忽略问题:utf-8 codec can't encode characters in :Invalid control character
#print(str(e))
continue
line = f.readline()
print("count is ",i,"error is ", error) if __name__ == "__main__": # 起到一个初始化或者调用函数的作用
db = pymysql.connect("localhost", "root", "******", "test", charset='utf8') #连接数据库test
cursor = db.cursor()
prem(db)
article_insert(db)
print('success')
cursor.close()
第一部分 创建表格 def prem(db)
首先需要在Mysql数据库里面先创建数据库test,然后调用sql语句创建表格article。
db.cursor() 其实就是用来获得python执行Mysql命令的方法,也就是操作游标
cursor.execute()执行sql语句
fetchone()则是接收返回结果行;fetchall()则是接受返回结果的多行记录
--参考fetchone和fetchall的介绍 https://blog.csdn.net/JackLiu16/article/details/78877460
如果对Mysql数据库语句和数据类型比较熟悉,可以直接在python里面直接创建表格;
如果不熟悉,建议在数据库创建好,因为Mysql里面的error code 比较详细,方便修改错误。
第二部分 数据插入 article_insert(db)
先用readline()逐行读取json数据
然后用json.loads()解析数据
--进一步理解区分load()和loads(),dump()和dumps()参考 https://www.cnblogs.com/bigtreei/p/10466518.html
再用executemany()同时执行多条语句,执行同样多的语句比execute()快很多
--参考executemany()和execute()的区别和应用https://www.cnblogs.com/zeke-python-road/p/9442152.html
用python导入20个G的json数据到Mysql数据库的更多相关文章
- python制作简单excel统计报表3之将mysql数据库中的数据导入excel模板并生成统计图
python制作简单excel统计报表3之将mysql数据库中的数据导入excel模板并生成统计图 # coding=utf-8 from openpyxl import load_workbook ...
- JSON文件存入MySQL数据库
目标:将不同格式的JSON文件存入MySQL数据库 涉及的点有: 1. java处理JSON对象,直接见源码. 2. java.sql.SQLException: Incorrect string v ...
- node.js存json数据到mysql
众所周知,mysql是无法存储json数据的,这个刚开始笔者也是知道的,也知道JSON.stringify()这个API的,但是当我真正要这样做利用JSON.stringify()讲要转换的JSON数 ...
- Python爬取招聘信息,并且存储到MySQL数据库中
前面一篇文章主要讲述,如何通过Python爬取招聘信息,且爬取的日期为前一天的,同时将爬取的内容保存到数据库中:这篇文章主要讲述如何将python文件压缩成exe可执行文件,供后面的操作. 这系列文章 ...
- Python实现将图片以二进制格式保存到MySQL数据库中,以及取出:
创建数据库表格式: CREATE TABLE photo ( photo_no int(6) unsigned NOT NULL auto_increment, image MEDIUMBLOB, P ...
- 飘逸的python - 命令行漂亮的显示json数据
之前做的一个脚本把信息用json格式存到文本中.这样的好处是简便,易编辑,并且拥有强大的表达能力. 不过从文本cat出来的是一堆很难看的字符串,没换行和缩进.这时候就在想,如果有个类似于IDE的格式化 ...
- Python web后端接收到的json数据有前端格式的布尔值 true false
最近在后端处理前端传过来的json数据,发现,因为数据是各种数据格式的嵌套,使用json.loads(),无法将内层的数据转换为原来格式的数据,所以需要使用eval( )函数进行转换,但是如果数据含有 ...
- MOOC(3)- python发送请求,返回的json数据被转码
https://www.cnblogs.com/yoyoketang/p/10339210.html 问题:发送post请求,对post请求返回的json数据格式化,但是返回的结果被转码了 json. ...
- python【第十二篇下】操作MySQL数据库以及ORM之 sqlalchemy
内容一览: 1.Python操作MySQL数据库 2.ORM sqlalchemy学习 1.Python操作MySQL数据库 2. ORM sqlachemy 2.1 ORM简介 对象关系映射(英语: ...
随机推荐
- 毒瘤dp 学校食堂
这道dp题 可谓是比较难了,我想了2h 总是觉得自己设的状态没有包涵全部的状态空间 一直想不出来状态 最后败北. 正解是这样的 我们肯定是有一维i的表示 到了i 这个人吃饭了 但是在i吃饭之前后面的7 ...
- luogu P5667 拉格朗日插值2 拉格朗日插值 多项式多点求值 NTT
LINK:P5667 拉格朗日插值2 给出了n个连续的取值的自变量的点值 求 f(m+1),f(m+2),...f(m+n). 如果我们直接把f这个函数给插值出来就变成了了多项式多点求值 这个难度好像 ...
- luogu4443 coci 2017 Dajave
题目 给出一个长度为2^M的排列,元素分别是0, 1, 2, ... , 2^M -1. 选择其中某个非空连续子序列,然后允许交换这个排列中某两个不同的数,然后使得这个连续子序列的所有数的按位异或(b ...
- Linux的VMWare中Centos7查看文件内容命令 (more-less-head-tail)
一.More分页查看文件 more 命令类似 cat ,不过会以一页一页的形式显示,更方便使用者逐页阅读, 而最基本的指令就是按空白键(space)就往下一页显示, 按 b 键就会往回(back)一页 ...
- 如何在Spring异步调用中传递上下文
以下文章来源于aoho求索 ,作者aoho 1. 什么是异步调用? 异步调用是相对于同步调用而言的,同步调用是指程序按预定顺序一步步执行,每一步必须等到上一步执行完后才能执行,异步调用则无需等待上一步 ...
- 【小白学AI】线性回归与逻辑回归(似然参数估计)
文章转自[机器学习炼丹术] 线性回归解决的是回归问题,逻辑回归相当于是线性回归的基础上,来解决分类问题. 1 公式 线性回归(Linear Regression)是什么相比不用多说了.格式是这个样子的 ...
- 郭超:阿里云Cassandra背后的故事
大家好,我是阿里云数据库产品事业部的玄陵,真名郭超. 本次的分享大概分三个部分:Cassandra云数据库简介.Cassandra云数据库特性以及Q&A. 我们先了解一下Cassand ...
- 从零写一个Asp.net core手脚架(模型验证)
一个asp.net core项目,一定包含了各种的实体,在RESTful api里面,有很多的参数传递,不建立实体则大量的参数需要自定验证正确性,并且Action上面会写的密密麻麻的参数 在asp.n ...
- 6月28日考试 题解(GCD约分+动态规划+树状数组二维偏序)
前言:考的一般般吧……T3暴力没打上来挺可惜的,到手的75分没了. ---------------------------------- T1 [JZOJ4745]看电影 Description 听说 ...
- 社区观点 | 理解比原链MOV链上交换协议
去中心化交换协议的发展 从Bitshare,Stellar到以太坊上的Etherdelta,Bancor,0x协议,去中心化交换协议也经过了好几代发展和很多模式的探索,每一代都通过前面的协议的痛点来进 ...