python数据处理(csv->折线图)

highs_lows.py

# -*- coding: utf-8 -*-
"""
Created on Mon May 29 10:00:16 2017

@author: Administrator
"""

import csv


filename = '300001_D.csv'
with open(filename) as f:
    reader = csv.reader(f)
    header_row = next(reader)
print(header_row)



with open(filename) as f:
    reader = csv.reader(f)
    header_row = next(reader)
    for index, column_header in enumerate(header_row):
        print(index, column_header)



with open(filename) as f:
    reader = csv.reader(f)
    header_row = next(reader)
    highs = []
    for row in reader:
        high=row[2]
        highs.append(high)
    print(highs)

highs_lows02.py

# -*- coding: utf-8 -*-
"""
Created on Mon May 29 10:59:38 2017

@author: Administrator
"""

import csv
from datetime import datetime
from matplotlib import pyplot as plt

filename = '300001_D.csv'        
with open(filename) as f:
    reader = csv.reader(f)
    header_row = next(reader)
    dates, highs = [],[]
    for row in reader:
        current_date = datetime.strptime(row[0], "%Y-%m-%d")
        dates.append(current_date)

        high=row[2]
        highs.append(high)
    print(dates, highs)



# 根据数据绘制图形
fig = plt.figure(dpi=128, figsize=(10, 6))
plt.plot(dates, highs, c='red')
# 设置图形的格式
plt.title("Daily high stock, July 2014", fontsize=24)
plt.xlabel('', fontsize=16)
fig.autofmt_xdate()
plt.ylabel("Number (F)", fontsize=16)
plt.tick_params(axis='both', which='major', labelsize=16)
plt.show()

highs_lows03.py

# -*- coding: utf-8 -*-
"""
Created on Mon May 29 11:08:22 2017

@author: Administrator
"""

import csv
from datetime import datetime
from matplotlib import pyplot as plt

filename = '300001_D.csv'        
with open(filename) as f:
    reader = csv.reader(f)
    header_row = next(reader)
    dates, highs, lows = [],[],[]
    for row in reader:
        try:
            current_date = datetime.strptime(row[0], "%Y-%m-%d")
            high=row[2]
            low = row[4]
        except ValueError:
            print(current_date, 'missing data')
        else:
            dates.append(current_date)
            highs.append(high)
            lows.append(low)

    print(dates, highs, lows)



# 根据数据绘制图形
fig = plt.figure(dpi=128, figsize=(10, 6))
#处的实参alpha 指定颜色的透明度。 Alpha 值为0表示完全透明, 
#1( 默认设置) 表示完全不透明
plt.plot(dates, highs, c='red', alpha=0.5)
plt.plot(dates, lows, c='blue', alpha=0.5)

# 设置图形的格式
plt.title("Daily high and low Stock, 2017-(01,05)", fontsize=24)
plt.xlabel('', fontsize=16)
fig.autofmt_xdate()
plt.ylabel("Number(F)", fontsize=16)
plt.tick_params(axis='both', which='major', labelsize=16)
plt.show()

输出图片:
这里写图片描述

原始数据以及源码打包

学习《python编程:从入门到实践》

  • 4
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值