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

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

部分示例图如下:

利用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 五个列表的数据

 利用ZIP方法转换

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


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

  • 4
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值