如何把获取的JSON数据插入到MySQL中

本文介绍了如何从官网爬取数据并将其保存为JSON文件,然后将该JSON数据插入到MySQL数据库中,包括创建JSON文件和执行导入的步骤。
摘要由CSDN通过智能技术生成

自己在官网上搞数据存为JSON 然后插入到MySQL里

1 直接爬官网的数据

  • 首先创建一个空的用来存放json文件的文件
// 需求: (1) 读取页面的html
//   (2) 把数据存入数据库,或存入data.json

//request模块: 发起http请求
// 安装 : cnpm i request --save 
const request = require("request");

// 把html代码转为类似jquery对象
const cheerio = require("cheerio");

const fs = require("fs");
const ms = require("./miData.json");//这是创建的空JSON文件 以便爬好直接存入进去


// 读取页面的html
function requestHtml() {
   
    return new Promise(function(resolve,reject){
   
        // request("https://www.vmall.com/huawei?cid=10618", function (err, res, data) {
   
        request("https://www.mi.com", function (err, res, data) {
    //这是爬取的官网地址 
            console.log(data.length,1)
            let $ = cheerio.load(data);
            let miData = [];//声明一个空数组用来接收爬取的数据
            // console.log($(".site-header .header-nav .nav-item .item-children li").find(".title").text())
            //这个是找到爬数据对应的类型
            $(".site-header .header-nav .nav-item .item-children li").each(function (index) {
   
                let goodsDetail = {
   
                    id: index + 1,
                    title: $(this).find(".title").text(),
                    desc: $(this).find(".desc11").text(),
                    price: $(this).find(".price").text()
                }
                miData.push(goodsDetail);
            })
            // // data已经构造完成
            resolve(miData)
        })
    })
}

function writeData(data) {
   
    //把上一步的数据写入miData.json
    // console.log(2)
    fs.writeFile("./miData.json",JSON.stringify(data),function(err){
   
        if (err){
   
            console.log('error')
        }else{
   
            console.log('success')
        }
    })
}

async function spider() {
   
    let data = await requestHtml();
    writeData(data);
}
spider();




// json结构
// [{
   
//     
### 回答1: 可以使用 Python 的 json 和 pymysql 库来实现解析 json 数据并写入到 MySQL 数据。 首先,需要安装 pymysql 库,可以使用以下命令进行安装: ``` pip install pymysql ``` 接着,假设我们有一个名为 data.jsonjson 数据文件,其包含了一些用户信息,如下所示: ``` { "users": [ { "name": "Alice", "age": 25, "email": "alice@example.com" }, { "name": "Bob", "age": 30, "email": "bob@example.com" }, { "name": "Charlie", "age": 35, "email": "charlie@example.com" } ] } ``` 我们可以使用以下代码将其的用户信息写入到 MySQL 数据: ```python import json import pymysql # 读取 json 文件 with open('data.json', 'r') as f: data = json.load(f) # 连接 MySQL 数据库 connection = pymysql.connect(host='localhost', user='root', password='password', database='test') # 获取游标 cursor = connection.cursor() # 遍历用户信息并插入数据 for user in data['users']: name = user['name'] age = user['age'] email = user['email'] sql = f"INSERT INTO users (name, age, email) VALUES ('{name}', {age}, '{email}')" cursor.execute(sql) # 提交事务并关闭连接 connection.commit() connection.close() ``` 在上面的代码,我们首先使用 json.load() 函数读取 json 文件数据,然后使用 pymysql.connect() 函数连接到 MySQL 数据库,接着使用 cursor.execute() 函数执行插入语句将用户信息插入数据,最后使用 connection.commit() 函数提交事务并关闭连接。 需要注意的是,上述代码使用了字符串插值来构造 SQL 语句,这种方式存在 SQL 注入的风险,应该避免直接使用用户输入的数据来构造 SQL 语句。更加安全的方式是使用参数化查询,如下所示: ```python # 使用参数化查询插入数据 sql = "INSERT INTO users (name, age, email) VALUES (%s, %s, %s)" values = [(user['name'], user['age'], user['email']) for user in data['users']] cursor.executemany(sql, values) ``` ### 回答2: Python可以使用内置的json库来解析json数据,并且可以使用第三方库如`pymysql`来连接和操作MySQL数据库。 首先,我们需要安装`pymysql`库,可以使用以下命令进行安装: ``` pip install pymysql ``` 然后,我们需要导入以下库: ```python import json import pymysql ``` 接下来,我们假设已经有一个名为`data.json`的json文件,其包含要写入MySQL数据库的数据。我们可以使用以下代码来解析json数据: ```python with open('data.json', 'r') as file: data = json.load(file) ``` 然后,我们需要连接到MySQL数据库。假设MySQL数据库位于本地,并具有以下凭据:主机名为`localhost`,用户名为`root`,密码为`password`,数据库名为`mydatabase`。我们可以使用以下代码连接到数据库: ```python connection = pymysql.connect(host='localhost', user='root', password='password', db='mydatabase', charset='utf8mb4', cursorclass=pymysql.cursors.DictCursor) ``` 接下来,我们可以插入数据数据。假设我们要将数据插入名为`mytable`的表。我们可以使用以下代码来实现: ```python with connection.cursor() as cursor: for item in data: # 根据数据结构进行修改 sql = "INSERT INTO mytable (column1, column2, column3) VALUES (%s, %s, %s)" cursor.execute(sql, (item['value1'], item['value2'], item['value3'])) connection.commit() ``` 最后,我们需要关闭数据库连接: ```python connection.close() ``` 以上就是使用Python解析json数据并写入MySQL数据库的基本步骤。请根据实际情况修改代码数据结构和表名。 ### 回答3: Python解析JSON数据并将其写入MySQL数据库的过程如下: 首先,我们需要导入必要的库:`json`和`mysql.connector`。 接下来,我们打开JSON文件并将其读取为一个字符串。可以使用内置的`open()`函数打开文件,并使用`.read()`方法读取文件内容。得到的结果是一个包含整个JSON数据的字符串。 然后,将字符串解析为JSON对象。使用`json.loads()`函数将字符串作为参数,返回一个JSON对象。这个JSON对象可以像字典一样访问和操作。 接下来,连接到MySQL数据库。使用`mysql.connector.connect()`函数建立与MySQL数据库的连接。需要提供正确的主机名、用户名、密码和数据库名称。 然后,创建一个游标对象。使用连接对象的`cursor()`方法创建一个游标对象。这个游标对象用于执行SQL语句和操作数据库。 接下来,创建一个INSERT查询。将JSON对象数据提取出来,并使用`INSERT INTO`语句插入到表。确保使用正确的表名和列名。 然后,执行INSERT查询。使用游标对象的`execute()`方法执行INSERT查询。 接下来,提交更改。使用连接对象的`commit()`方法提交更改,以保存对数据库的更新。 最后,关闭连接。使用连接对象的`close()`方法关闭与数据库的连接。 在代码的最后,你可以选择将所有的步骤封装在一个函数,以便更方便地重用和调用。 这就是使用Python解析JSON数据并将其写入MySQL数据库的基本过程。希望对你有所帮助!
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值