python之把列表的值成列写入csv文件

一般我们csv写入数据都是一行一行写入的,如何一列一列写入呢,这里拿了个tiobe编程语言排行榜来说明        index | TIOBE - The Software Quality Company

部分示例图如下:

python之把列表的值成列写入csv文件_第1张图片

利用python的requests库和xpath提取数据,及csv保存数据:

# -*- coding:utf-8 -*-
# author Zion
import requests
import lxml.html
import csv

url = "https://www.tiobe.com/tiobe-index/"
headers = {
    "user-agent": "自己的UA值XXX"
}
response = requests.get(url,headers=headers)
html_data = response.text
# print(html_data)
# 获取etree对象
metree = lxml.html.etree
# 获取数据对象
parser = metree.HTML(html_data, metree.HTMLParser())
# 解析数据
titles = parser.xpath('//*[@id="top20"]/thead//tr//th/text()')
# print(titles)
Feb2022 = parser.xpath('//*[@id="top20"]/tbody/tr/td[1]/text()')
Feb2021 = parser.xpath('//*[@id="top20"]/tbody/tr/td[2]/text()')
programming_Language = parser.xpath('//*[@id="top20"]/tbody/tr/td[5]/text()')
ratings = parser.xpath('//*[@id="top20"]/tbody/tr/td[6]/text()')
change = parser.xpath('//*[@id="top20"]/tbody/tr/td[7]/text()')
# zip转换
rows = zip(Feb2022, Feb2021, programming_Language, ratings, change)
with open("language_data.csv", "w", newline="") as f:
    writer = csv.writer(f)
    writer.writerow(["Feb2022", "Feb2021", "programming_Language", "ratings", "change"])
    for row in rows:
        writer.writerow(row)
print("程序运行成功!")

这里分别拿到Feb2022、Feb2021、programming_Language、ratings、change 五个列表的数据

python之把列表的值成列写入csv文件_第2张图片

 利用ZIP方法转换python之把列表的值成列写入csv文件_第3张图片

 最后展示数据,可以看到python还是挺猛的,冲到前面了TvT 

python之把列表的值成列写入csv文件_第4张图片


博主水平有限,分享只是个人的学习心得,欢迎大神指出代码不足之处,一起学习进步 

你可能感兴趣的:(python,list,csv)