-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhighs_lows.py
54 lines (43 loc) · 1.42 KB
/
highs_lows.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#!/usr/bin/env python3
# -*- encoding: utf-8 -*-
import csv
from datetime import datetime
import matplotlib.pyplot as plt
first_date = datetime.strptime("2014-07-01", "%Y-%m-%d")
print(first_date)
# 读取文件头
filename = 'death_valley_2014.csv'
with open(filename) as f:
reader = csv.reader(f)
head_row = next(reader)
print(head_row)
# 打印文件头及其位置
for index, column_header in enumerate(head_row):
print(index, column_header)
# 从文件中获取日期、最高气温和最低气温
dates, highs, lows = [], [], []
for row in reader:
try:
current_date = datetime.strptime(row[0], '%Y-%m-%d')
high = int(row[1])
low = int(row[3])
except ValueError:
print(current_date, 'missing data')
else:
dates.append(current_date)
highs.append(high)
lows.append(low)
print(highs)
# 设置绘图窗口的尺寸
fig = plt.figure(dpi=128, figsize=(10, 6))
plt.plot(dates, highs, c='red')
plt.plot(dates, lows, c='blue')
# 着色
plt.fill_between(dates, highs, lows, facecolor='blue', alpha=0.5)
# 设置图形的格式
plt.title("Daily high temperatures 2014", fontsize=24)
plt.xlabel('', fontsize=16)
fig.autofmt_xdate()
plt.ylabel("Temperature (F)", fontsize=16)
plt.tick_params(axis='both', which='major', labelsize=16)
plt.show()