Python数据可视化(处理天气数据)

从csv文件中导入数据。

import csvwith open('sitka_weather_07-2014.csv', 'r') as f:reader = csv.reader(f)for row in reader:print(row)
['AKDT', 'Max TemperatureF', 'Mean TemperatureF', 'Min TemperatureF', 'Max Dew PointF', 'MeanDew PointF', 'Min DewpointF', 'Max Humidity', ' Mean Humidity', ' Min Humidity', ' Max Sea Level PressureIn', ' Mean Sea Level PressureIn', ' Min Sea Level PressureIn', ' Max VisibilityMiles', ' Mean VisibilityMiles', ' Min VisibilityMiles', ' Max Wind SpeedMPH', ' Mean Wind SpeedMPH', ' Max Gust SpeedMPH', 'PrecipitationIn', ' CloudCover', ' Events', ' WindDirDegrees']
['2014-7-1', '64', '56', '50', '53', '51', '48', '96', '83', '58', '30.19', '30.00', '29.79', '10', '10', '10', '7', '4', '', '0.00', '7', '', '337']
['2014-7-2', '71', '62', '55', '55', '52', '46', '96', '80', '51', '29.81', '29.75', '29.66', '10', '9', '2', '13', '5', '', '0.14', '7', 'Rain', '327']
['2014-7-3', '64', '58', '53', '55', '53', '51', '97', '85', '72', '29.88', '29.86', '29.81', '10', '10', '8', '15', '4', '', '0.01', '6', '', '258']
['2014-7-4', '59', '56', '52', '52', '51', '50', '96', '88', '75', '29.91', '29.89', '29.87', '10', '9', '2', '9', '2', '', '0.07', '7', 'Rain', '255']
['2014-7-5', '69', '59', '50', '52', '50', '46', '96', '72', '49', '29.88', '29.82', '29.79', '10', '10', '10', '13', '5', '', '0.00', '6', '', '110']
['2014-7-6', '62', '58', '55', '51', '50', '46', '80', '71', '58', '30.13', '30.07', '29.89', '10', '10', '10', '20', '10', '29', '0.00', '6', 'Rain', '213']
['2014-7-7', '61', '57', '55', '56', '53', '51', '96', '87', '75', '30.10', '30.07', '30.05', '10', '9', '4', '16', '4', '25', '0.14', '8', 'Rain', '211']
['2014-7-8', '55', '54', '53', '54', '53', '51', '100', '94', '86', '30.10', '30.06', '30.04', '10', '6', '2', '12', '5', '23', '0.84', '8', 'Rain', '159']
['2014-7-9', '57', '55', '53', '56', '54', '52', '100', '96', '83', '30.24', '30.18', '30.11', '10', '7', '2', '9', '5', '', '0.13', '8', 'Rain', '201']
['2014-7-10', '61', '56', '53', '53', '52', '51', '100', '90', '75', '30.23', '30.17', '30.03', '10', '8', '2', '8', '3', '', '0.03', '8', 'Rain', '215']
['2014-7-11', '57', '56', '54', '56', '54', '51', '100', '94', '84', '30.02', '30.00', '29.98', '10', '5', '2', '12', '5', '', '1.28', '8', 'Rain', '250']
['2014-7-12', '59', '56', '55', '58', '56', '55', '100', '97', '93', '30.18', '30.06', '29.99', '10', '6', '2', '15', '7', '26', '0.32', '8', 'Rain', '275']
['2014-7-13', '57', '56', '55', '58', '56', '55', '100', '98', '94', '30.25', '30.22', '30.18', '10', '5', '1', '8', '4', '', '0.29', '8', 'Rain', '291']
['2014-7-14', '61', '58', '55', '58', '56', '51', '100', '94', '83', '30.24', '30.23', '30.22', '10', '7', '0', '16', '4', '', '0.01', '8', 'Fog', '307']
['2014-7-15', '64', '58', '55', '53', '51', '48', '93', '78', '64', '30.27', '30.25', '30.24', '10', '10', '10', '17', '12', '', '0.00', '6', '', '318']
['2014-7-16', '61', '56', '52', '51', '49', '47', '89', '76', '64', '30.27', '30.23', '30.16', '10', '10', '10', '15', '6', '', '0.00', '6', '', '294']
['2014-7-17', '59', '55', '51', '52', '50', '48', '93', '84', '75', '30.16', '30.04', '29.82', '10', '10', '6', '9', '3', '', '0.11', '7', 'Rain', '232']
['2014-7-18', '63', '56', '51', '54', '52', '50', '100', '84', '67', '29.79', '29.69', '29.65', '10', '10', '7', '10', '5', '', '0.05', '6', 'Rain', '299']
['2014-7-19', '60', '57', '54', '55', '53', '51', '97', '88', '75', '29.91', '29.82', '29.68', '10', '9', '2', '9', '2', '', '0.00', '8', '', '292']
['2014-7-20', '57', '55', '52', '54', '52', '50', '94', '89', '77', '29.92', '29.87', '29.78', '10', '8', '2', '13', '4', '', '0.31', '8', 'Rain', '155']
['2014-7-21', '69', '60', '52', '53', '51', '50', '97', '77', '52', '29.99', '29.88', '29.78', '10', '10', '10', '13', '4', '', '0.00', '5', '', '297']
['2014-7-22', '63', '59', '55', '56', '54', '52', '90', '84', '77', '30.11', '30.04', '29.99', '10', '10', '10', '9', '3', '', '0.00', '6', 'Rain', '240']
['2014-7-23', '62', '58', '55', '54', '52', '50', '87', '80', '72', '30.10', '30.03', '29.96', '10', '10', '10', '8', '3', '', '0.00', '7', '', '230']
['2014-7-24', '59', '57', '54', '54', '52', '51', '94', '84', '78', '29.95', '29.91', '29.89', '10', '9', '3', '17', '4', '28', '0.06', '8', 'Rain', '207']
['2014-7-25', '57', '55', '53', '55', '53', '51', '100', '92', '81', '29.91', '29.87', '29.83', '10', '8', '2', '13', '3', '', '0.53', '8', 'Rain', '141']
['2014-7-26', '57', '55', '53', '57', '55', '54', '100', '96', '93', '29.96', '29.91', '29.87', '10', '8', '1', '15', '5', '24', '0.57', '8', 'Rain', '216']
['2014-7-27', '61', '58', '55', '55', '54', '53', '100', '92', '78', '30.10', '30.05', '29.97', '10', '9', '2', '13', '5', '', '0.30', '8', 'Rain', '213']
['2014-7-28', '59', '56', '53', '57', '54', '51', '97', '94', '90', '30.06', '30.00', '29.96', '10', '8', '2', '9', '3', '', '0.61', '8', 'Rain', '261']
['2014-7-29', '61', '56', '51', '54', '52', '49', '96', '89', '75', '30.13', '30.02', '29.95', '10', '9', '3', '14', '4', '', '0.25', '6', 'Rain', '153']
['2014-7-30', '61', '57', '54', '55', '53', '52', '97', '88', '78', '30.31', '30.23', '30.14', '10', '10', '8', '8', '4', '', '0.08', '7', 'Rain', '160']
['2014-7-31', '66', '58', '50', '55', '52', '49', '100', '86', '65', '30.31', '30.29', '30.26', '10', '9', '3', '10', '4', '', '0.00', '3', '', '217']

由于reader是一个生成器(next方法调用),且为了更好的观察文件,先把文件的头打出来,即第一行。

with open('sitka_weather_07-2014.csv', 'r') as f:reader = csv.reader(f)header_row = next(reader)for index, content in enumerate(header_row):print(index, content)
0 AKDT
1 Max TemperatureF
2 Mean TemperatureF
3 Min TemperatureF
4 Max Dew PointF
5 MeanDew PointF
6 Min DewpointF
7 Max Humidity
8  Mean Humidity
9  Min Humidity
10  Max Sea Level PressureIn
11  Mean Sea Level PressureIn
12  Min Sea Level PressureIn
13  Max VisibilityMiles
14  Mean VisibilityMiles
15  Min VisibilityMiles
16  Max Wind SpeedMPH
17  Mean Wind SpeedMPH
18  Max Gust SpeedMPH
19 PrecipitationIn
20  CloudCover
21  Events
22  WindDirDegrees

这里我们关注的是最高气温。即第一列和第二列的数据(也就是我们对所有行进行处理,取每一行的前两个数据)。

with open('sitka_weather_07-2014.csv', 'r') as f:reader = csv.reader(f)#先把文件头取出来header_row = next(reader)date = []max_temperature = []for row in reader:date.append(row[0])max_temperature.append(int(row[1]))
print(date, max_temperature)
['2014-7-1', '2014-7-2', '2014-7-3', '2014-7-4', '2014-7-5', '2014-7-6', '2014-7-7', '2014-7-8', '2014-7-9', '2014-7-10', '2014-7-11', '2014-7-12', '2014-7-13', '2014-7-14', '2014-7-15', '2014-7-16', '2014-7-17', '2014-7-18', '2014-7-19', '2014-7-20', '2014-7-21', '2014-7-22', '2014-7-23', '2014-7-24', '2014-7-25', '2014-7-26', '2014-7-27', '2014-7-28', '2014-7-29', '2014-7-30', '2014-7-31'] [64, 71, 64, 59, 69, 62, 61, 55, 57, 61, 57, 59, 57, 61, 64, 61, 59, 63, 60, 57, 69, 63, 62, 59, 57, 57, 61, 59, 61, 61, 66]

先画出图。

import matplotlib.pyplot as pltplt.plot(max_temperature)
plt.show()

对图进行一些美化。

#设置图片大小
fig = plt.figure(dpi=128, figsize=(10, 6))
plt.plot(max_temperature, linewidth=2)#设置标题以及x,y轴标签
plt.title('Daily high temperatures, July 2014', fontsize=24)
plt.xlabel('Day', fontsize=18)
plt.ylabel('Temperature(F)', fontsize=18)plt.show()

由于背景是黑色的,可以通过将字体的格式设置为一个字典传入title和label方法中。

#设置图片大小
fig = plt.figure(dpi=128, figsize=(10, 6))
plt.plot(max_temperature, linewidth=2)
#设置字体
font1 = {'family': 'Times New Roman','color':  'white','weight': 'normal','size': 24}
font2 = {'family': 'Times New Roman','color': 'white','weight': 'normal','size': 18}
#设置标题以及x,y轴标签
plt.title('Daily high temperatures, July 2014', fontdict=font1)
plt.xlabel('Day', fontdict=font2)
plt.ylabel('Temperature(F)', fontdict=font2)
plt.tick_params()plt.show()

博客里背景变成白色了(T^T),总之可以通过字典的形式来设置字体的格式。

Python数据可视化(处理天气数据)相关推荐

  1. 【爬虫+数据可视化毕业设计:英雄联盟数据爬取及可视化分析,python爬虫可视化/数据分析/大数据/大数据屏/数据挖掘/数据爬取,程序开发-哔哩哔哩】

    [爬虫+数据可视化毕业设计:英雄联盟数据爬取及可视化分析,python爬虫可视化/数据分析/大数据/大数据屏/数据挖掘/数据爬取,程序开发-哔哩哔哩] https://b23.tv/TIoy6hj

  2. python 财务分析可视化方法_Python数据可视化的四种简易方法

    Python数据可视化的四种简易方法 作者:PHPYuan 时间:2018-11-28 03:40:43 摘要: 本文讲述了热图.二维密度图.蜘蛛图.树形图这四种Python数据可视化方法. 数据可视 ...

  3. 【【数据可视化毕业设计:差旅数据可视化分析,python爬虫可视化/数据分析/大数据/大数据屏/数据挖掘/数据爬取,程序开发-哔哩哔哩】-哔哩哔哩】 https://b23.tv/iTt30QG

    [[数据可视化毕业设计:差旅数据可视化分析,python爬虫可视化/数据分析/大数据/大数据屏/数据挖掘/数据爬取,程序开发-哔哩哔哩]-哔哩哔哩] https://b23.tv/iTt30QG ht ...

  4. 数据可视化:世界银行数据(1960-2017)

    数据可视化:世界银行数据(1960-2017) 我选择并下载了数据集The World Bank Data by Indicators 1960-2017用于这次的作业,并选择 Jupyter Not ...

  5. 数据可视化分析票房数据报告_票房收入分析和可视化

    数据可视化分析票房数据报告 Welcome back to my 100 Days of Data Science Challenge Journey. On day 4 and 5, I work ...

  6. C#+HtmlAgilityPack+XPath带你采集数据(以采集天气数据为例子)

    [转]C#+HtmlAgilityPack+XPath带你采集数据(以采集天气数据为例子) 第一次接触HtmlAgilityPack是在5年前,一些意外,让我从技术部门临时调到销售部门,负责建立一些流 ...

  7. 数据可视化笔记1 数据可视化简介(简史、分类、功能、目标)

    文章目录 1.什么是数据可视化 2.为什么要数据可视化 3.数据可视化简史 4.数据可视化的分类 5.数据可视化的功能 6.数据可视化的目标 7.数据可视化工具 1.什么是数据可视化 数据可视化: 创 ...

  8. 漏刻有时数据可视化大屏数据可视化动态模拟演示与自动轮播

    在数据可视化开发的过程中,存在着两种动画效果.一种是KPI指标的模拟演示动画数字滚动累加效果,一种是Echarts图表自动轮播实现自动演示的动画效果. 一.KPI指标的模拟演示动画数字滚动累加效果 实 ...

  9. 【数据分析学习笔记day25】实战案例:世界高峰数据可视化+世界高峰数据可视化 (World's Highest Mountains)

    文章目录 实战案例:世界高峰数据可视化 世界高峰数据可视化 (World's Highest Mountains) 实战案例:世界高峰数据可视化 世界高峰数据可视化 (World's Highest ...

  10. 数据可视化学习(数据可视化基本概念)

    本篇文章翻译自数据可视化入门教程 数据可视化(Data Visualization)和信息可视化(Infographics)是两个相近的专业领域名词.狭义上的数据可视化指的是数据用统计图表方式呈现,而 ...

最新文章

  1. mysql-5.5.59安装_MySQL-5.5 安装
  2. sort用法(默认按升序排列)
  3. VLC播放器web插件接口(Part1)
  4. log4net简单配置打印日志
  5. [react] 说说你对reader的context的理解
  6. C++语言基础 —— STL —— 算法 —— unique() 的使用
  7. CTS ( 19)---Android 8.1/GO GMS认证
  8. GridView中不能用If?
  9. [收藏]深入浅出的《网络socket编程指南》4
  10. Linux查看文件以及文件夹个数
  11. java编程简单小游戏_求一个简单又有趣的JAVA小游戏代码
  12. 局域网打印机怎么连接_mac连接局域网打印机
  13. 这些论文绘图软件,你一个都不会用
  14. 键盘+moveit+rviz 控制六轴机械臂(仿真)
  15. deepin升级到20.2,开机显示deepin LOGO之后屏幕黑屏解决办法
  16. 手把手教你做第一个RPA机器人流程
  17. 静态检测工具STATIC以及静态分析的必要性
  18. 6月世界自行车日 今天聊聊斯柯达
  19. java 图片 rgb_简单的java图片处理——如何用Java读出一张图片的RGB值?
  20. Qt知识点梳理 —— 国际化 QtLinguist 应用(1)

热门文章

  1. 用Pandas分析了75w多条数据,揭秘美国选民的总统喜好!
  2. 自制RC自动驾驶+遥控智能小车
  3. zookeeper重零开始--------自学(借鉴一些视频,书籍等工具)
  4. UglifyJS和Uglifycss使用
  5. [BZOJ2095][Poi2010]Bridges 最大流(混合图欧拉回路)
  6. mysql深入优化篇
  7. Nonebot QQ机器人插件三:王者荣耀猜英雄游戏
  8. 【机器学习】数据挖掘/知识发现/人工智能相关概念梳理
  9. 基石为勤能补拙的迷宫之旅——第二天(编程语言介绍、Python解释器介绍与安装、执行Python程序的方式和变量)
  10. Mac OS 禁止屏幕休眠的方法