1.csv简单小案例
import csv
header = ['姓名', '年龄', '性别']
data = [
['张三', 25, '男'],
['李四', 35, '女']
]
# newline=''消除空行
with open('数据写入.csv', 'w', encoding='gbk', newline='')as f:
# 第一步 实例化写入对象
w = csv.writer(f)
# 第二部写入表头
w.writerow(header)
# 第三步 写入多行数据
w.writerows(data)
# PermissionError: [Errno 13] Permission denied: '数据写入.csv'
# 文件未关闭
data:image/s3,"s3://crabby-images/2d73e/2d73ec6e08d0946fbdef0731e08930a46b8d31a3" alt=""
2.实战-腾讯招聘信息(仅供学习考)
data:image/s3,"s3://crabby-images/8bc57/8bc571d192b71c0f537a2b3a78cbf8af4c2e18e8" alt=""
import requests, jsonpath, time, csv
class Start(object):
# 类实例化时会执行
def __init__(self):
self.headers = {
'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/107.0.0.0 Safari/537.36'
}
self.sum_list = []
self.h = [
'招聘职位',
'国家',
'地区',
'类别',
'任务',
'最新日期',
'工作需求'
]
def get_html(self, index):
print(f'当前页数{index}============')
url = f'https://careers.tencent.com/tencentcareer/api/post/Query?timestamp={int(time.time() * 1000)}&countryId=&cityId=&bgIds=&productId=&categoryId=40001001&parentCategoryId=&attrId=&keyword=&pageIndex={index}&pageSize=10&language=zh-cn&area='
response = requests.get(url, headers=self.headers)
# 提取数据
json_data = response.json() # 将响应当中的内容取成json格式 字典 列表
# 解析数据
RecruitPostName = jsonpath.jsonpath(json_data, '$..RecruitPostName') # 匹配时不能有空格
CountryName = jsonpath.jsonpath(json_data, '$..CountryName')
LocationName = jsonpath.jsonpath(json_data, '$..LocationName')
CategoryName = jsonpath.jsonpath(json_data, '$..CategoryName')
Responsibility = jsonpath.jsonpath(json_data, '$..Responsibility')
LastUpdateTime = jsonpath.jsonpath(json_data, '$..LastUpdateTime')
RequireWorkYearsName = jsonpath.jsonpath(json_data, '$..RequireWorkYearsName')
# 整合数据
for i in zip(RecruitPostName, CountryName, LocationName, CategoryName, Responsibility, LastUpdateTime,
RequireWorkYearsName):
lis = [i[0],
i[1],
i[2],
i[3],
i[4].replace('\r', '').replace('\n', ''),
i[5],
i[6]]
self.sum_list.append(lis)
def save_csv(self):
# print(self.sum_list)
with open('腾讯招聘.csv', 'w', encoding='gbk', newline='')as f:
# 第一步 实例化写入对象
w = csv.writer(f)
# 第二部写入表头
w.writerow(self.h)
# 第三步 写入多行数据
w.writerows(self.sum_list)
if __name__ == '__main__':
s = Start() # 实例化类对象
for index in range(1, 11):
s.get_html(index)
s.save_csv()
data:image/s3,"s3://crabby-images/4041f/4041f148437c27a4bd58d1f471bd1c1469cf66f2" alt=""
3.当当网书籍信息,上传到资源
data:image/s3,"s3://crabby-images/d2a62/d2a62683d44f63414beeeca69c8d018f5df123ca" alt=""