时间序列(pandas)

1.时间序列的生成

pd.date_range(start=“20201125”,periods=10,freq=“M”)
注意索引词:periods 和 freq!!!

import pandas as pd
import numpy as np

df2=pd.date_range(start="20201125",periods=10,freq="M")
print(df2)
C:\Users\zxh\Anaconda3\python.exe D:/PycharmProjects/MyTest/day5.py
DatetimeIndex(['2020-11-30', '2020-12-31', '2021-01-31', '2021-02-28',
               '2021-03-31', '2021-04-30', '2021-05-31', '2021-06-30',
               '2021-07-31', '2021-08-31'],
              dtype='datetime64[ns]', freq='M')

pd.to date_time( , )

时间格式化

2.pandas 重采样和聚合

一个时间频率转换为另一种时间频率
pd.resample().mean/count()

df.head( )
df.info( )

2.1时间类型转化period方法

#把分开的时间字符串通过periodIndex的方法转化为pandas的时间类型
period = pd.PeriodIndex(year=df["year"],month=df["month"],day=df["day"],hour=df["hour"],freq="H")
df["datetime"] = period
# print(df.head(10))
_x = [i.strftime("%Y%m%d") for i in _x]
_x_china = [i.strftime("%Y%m%d") for i in data_china.index]

2.2降采样

#进行降采样
df = df.resample("7D").mean()

报错处理

'utf-8' codec can't decode byte 0xbb in position 25: invalid start byte

!!!把路径名都改成中文就完事。

#画图
_x = data.index
_x = [i.strftime("%Y%m%d") for i in _x]
_x_china = [i.strftime("%Y%m%d") for i in data_china.index]
print("!!!!!!",len(_x_china),len(_x_china),_x)
_y = data.values
_y_china = data_china.values

结果

!!!!!! 313 313 ['20100101', '20100108', '20100115', '20100122', '20100129', '20100205'
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值