数据存储(JSON文件存储,CSV文件存储)

1.2 JSON文件存储

JSON全称为JavaScript Object Notation,也就是JavaScript对象标记,它通过对象和数组的组合来表示数据,构造简介但是结构化程度非常高,是一种轻量级的数据交换格式。
1.2.1 对象和数组
对象:它在JavaScript中是使用花括号{}包裹起来的内容,数据结构为{key1: value1, key2: value2, …}的键值对结构。在面向对象的语言中,key为对象的属性,value为对应的值。键名可以使用整数和字符串来表示。值的类型可以是任意类型。
数组:数组在Javascript中是方括号[ ]包裹起来的内容,数据结构为[“java”, “javascript”, “python”, …]的索引结构。在Javascript中数组是一种比较特殊的数据类型,它也可以像对象那样使用键值对,但还是索引用得多。同样,值的类型可以是任意类型。
一个JSON对象可以写为如下形式:

[{
    "name": "cjh",
    "sex": "boy",
    "birthday": "1999-04-02"
    },{
    "name": "mx",
    "sex": "boy",
    "birthday": "1998-10-02"
    }]

这就相当于列表与字典之间的嵌套。
1.2.2 读取JSON
可以调用JSON库的loads()方法将JSON文本字符串转为JSON对象,可以通过dumps()方法将JSON对象转为文本字符串。

import json
str = '''
[{
    "name": "cjh",
    "sex": "boy",
    "birthday": "1999-04-02"
    },{
    "name": "mx",
    "sex": "boy",
    "birthday": "1998-10-02"
    }]
'''
print(type(str))
data = json.loads(str)
print(type(data))
print(data)

loads()方法将字符串转为JSON对象。由于最外层是中括号,所以最终类型是列表类型。
在这里插入图片描述
1.2.3 输出JSON
可以使用dumps()方法将JSON对象转化为字符串。

import json
data=[{
    "name": "cjh",
    "sex": "boy",
    "birthday": "1999-04-02"}]
with open('data.json', 'w') as f:
    f.write(json.dumps(data))    

如果想保存JSON的格式,可以再加一个参数indent,代表缩进字符个数。
如果JSON中包含中文字符,需要指定参数ensure_ascii为False,另外还要规定文件输出的编码:

with open('data.json', 'w', encoding='utf-8') as f:
    f.write(json.dumps(data, ensure_ascii=False))   

1.3 CSV文件存储

1.3.1 写入

import csv
with open('data.csv', 'w') as f:
    # 调用csv库的writer()方法初始化写入对象
    writer = csv.writer(f)
    # 调用writerow()方法传入每行的数据
    writer.writerow(['id', 'name', 'age'])
    writer.writerow(['1001', 'mike', '20'])
    writer.writerow(['1002', 'luck', '21'])
    writer.writerow(['1003', 'chen', '22'])

如果想要修改列与列直接的分隔符,可以在writer()方法中传入delimiter参数。
使用writerows()写入多行:

import csv
with open('data.csv', 'w') as f:
    # 调用csv库的writer()方法初始化写入对象
    writer = csv.writer(f)
    writer.writerow(['id', 'name', 'age'])
    writer.writerows([['1001', 'mike', '20'], ['1002', 'luck', '21'], ['1003', 'chen', '22']])

字典的写入方法:

import csv
with open('data.csv', 'w') as f:
    # 先定义字段
    filednames = ['id', 'name', 'age']
    # 调用DictWriter()方法来初始化一个写入对象
    writer = csv.DictWriter(f, filednames=filednames)
    # 调用writeheader()方法写入头信息
    writer.writeheader()
    writer.writerow({'id': '1001', 'name': 'mike', 'age': 20})
    writer.writerow({'id': '1002', 'name': 'luck', 'age': 21})
    writer.writerow({'id': '1003', 'name': 'chen', 'age': 22})

如果想追加写入的话,将文件打开模式修改为a就可以了。
写入中文内容的话,需要给open()参数指定编码格式:encoding=‘utf-8’。

1.3.2 读取

import csv
with open('data.csv', 'r') as f:
    reader = csv.reader(f)
    for row in reader:
        print(row)
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天意不可违.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值