第十八天:CSV、JSON、Excel、SQLite

一、CSV文件

1、读取

  • reader = csv.reader(打开的file对象), reader为可迭代对象

2、用namedtuple映射列名

with open('apple.csv') as f:
	reader = csv.reader(f)
	headers = next(reader)	# 一般第一行是属性名
	Row = namedtuple('Row',headers)
	for r in reader:
		row = Row(*r)
		print(row)

3、读取到字典表

with open('a.csv') as f:
	reader = csv.DictReader(f)
	for row in reader:
		print(row)

二、JSON模块

  • json.dumps() 转换成json类型的字符串
  • json.loads() 从json字符串读取
  • json.dump(data,file) 写json文件
  • json.load(file) 读json文件
  • json中的false为None

三、excel 模块

使用xlrd模块

  • a = xlrd.open_workbook(file) 读取excel文件
  • for sheet in book.sheets(): 遍历文件中的工作簿
  • book.sheet_by_index() 按下标找工作簿
  • book.sheet_by_name() 按名称找工作簿
  • sheet.name 工作簿名
  • sheet.nrows 数据行数
  • sheet.row_values(index) 获取索引指定的数据行

四、excel 模块

1、动态类型

  • NULL
  • INTEGER
  • REAL
  • TEXT
  • BLOB

2、操作

sqlite3模块

  • 连接对象
    .connect(‘file.db’)
    • commit()
    • close()
  • 游标
    cursor
    cursor=conn.cursor()
    执行语句 cursor.execute(‘SQL’,[参数])
    获取所有结果到列表 cursor.fetchall()
    获取一条结果 cursor.fetchone()
    获取指定条结果 cursor.fetchmany(num)
  • 参数化查询
    避免SQL注入
    • ?参数传递元组
    • :参数名 传递字典表
posted @ 2019-09-16 23:08  败家小林  阅读(193)  评论(0编辑  收藏  举报