久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

第十一篇 时间序列

發布時間:2024/7/5 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 第十一篇 时间序列 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

時間序列(time series)數據是?種重要的結構化數據形式,應?于多個領域,包括?融學、經濟學、?態學、神經科學、物理學等。在多個時間點觀察或測量到的任何事物都可以形成?段時間序列。很多時間序列是固定頻率的,也就是說,數據點是根據某種規律定期出現的(?如每15秒、每5分鐘、每?出現?次)。時間序列也可以是不定期的,沒有固定的時間單位或單位之間的偏移量。時間序列數據的意義取決于具體的應?場景,主要有以下?種:
???????? 時間戳(timestamp),特定的時刻。
???????? 固定時期(period),如2007年1?或2010年全年。
???????? 時間間隔(interval),由起始和結束時間戳表示。時期(period)可以被看做間隔(interval)的特例。
???????? 實驗或過程時間,每個時間點都是相對于特定起始時間的?個度量。例如,從放?烤箱時起,每秒鐘餅?的直徑。

本篇主要講解前3種時間序列。許多技術都可?于處理實驗型時間序列,其索引可能是?個整數或浮點數(表示從實驗開始算起已經過去的時間)。最簡單也最常?的時間序列都是?時間戳進?索引的。

注意:pandas也?持基于timedeltas的指數,它可以有效代表實驗或經過的時間。可以在pandas的官方?檔學習timedelta指數(http://pandas.pydata.org/)。

pandas提供了許多內置的時間序列處理?具和數據算法。因此,你可以?效處理?常?的時間序列,輕松地進?切?/切塊、聚合、對定期/不定期的時間序列進?重采樣等。有些?具特別適合?融和經濟應?,你當然也可以?它們來分析服務器?志數據。

一、?期和時間數據類型及?具
Python標準庫包含?于?期(date)和時間(time)數據的數據類型,?且還有?歷??的功能。我們主要會?到datetime、time以及calendar模塊。datetime.datetime(也可以簡寫為datetime)是?得最多的數據類型
from datetime import datetime
now = datetime.now()
now???????? # 輸出:datetime.datetime(2018, 12, 20, 14, 43, 59, 744323)
now.year, now.month, now.day??????? # 輸出:(2018, 12, 20)

datetime以毫秒形式存儲?期和時間。timedelta表示兩個datetime對象之間的時間差
delta = datetime(2018, 8, 1) - datetime(2018, 3, 1, 9, 14)
delta????????????????????? # 輸出:datetime.timedelta(152, 53160)
delta.days???????????? # 輸出:152
delta.seconds????? # 輸出:53160

可以給datetime對象加上(或減去)?個或多個timedelta,這樣會產??個新對象:
from datetime import timedelta
start = datetime(2016, 3, 2)
start + timedelta(12)??????????? # 輸出:datetime.datetime(2016, 3, 14, 0, 0),加12天
start - 2 * timedelta(12)?????? # 輸出:datetime.datetime(2016, 2, 7, 0, 0),減24天
datetime模塊中的數據類型參?表11-1。雖然本篇主要講的是pandas數據類型和?級時間序列處理,但你肯定會在Python的其他地?遇到有關datetime的數據類型。

表11-1 datetime模塊中的數據類型
類型????????????? 說明
date????????????? 以公歷形式存儲日歷日期(年、月、日)
time????????????? 將時間存儲為時、分、秒、毫秒
datetime?????? 存儲日期和時間
timedelta????? 表示兩個datetime值之間的差(日、秒、毫秒)
tzinfo??????????? 存儲時區信息的基本類型

1、字符串和datetime的相互轉換
利?str或strftime?法(傳??個格式化字符串),datetime對象和pandas的Timestamp對象(稍后就會介紹)可以被格式化為字符串:
stamp = datetime(2016, 3, 2)
str(stamp)????? # 輸出 :'2016-03-02 00:00:00'
stamp.strftime('%Y-%m-%d')????? # 輸出: '2016-03-02'
表11-2列出了全部的格式化編碼。

表11-2 datetime格式定義(兼容ISO C89)
代碼????????? 說明
%Y??????????? 4位數的年
%y??????????? 2位數的年
%m?????????? 2位數的月[01, 12]
%d??????????? 2位數的日[01, 31]
%H??????????? 時(24小時制)[00, 23]
%I????????????? 時(12小時制)[01, 12]
%M?????????? 2位數的分[00, 59]
%S???????????? 秒[00, 61](秒60和61用于閏秒)
%w??????????? 用整數表示的星期幾 [ 0(星期天), 6]
%U??????????? 每年的第幾周[00, 53]。星期天被認為是每周的第一天,每年的第一個
????????????????? 星期天之前的那幾天被認為是“第0周”
%W?????????? 每年的第幾周[00, 53]。星期一被認為是每周的第一天,每年的第一個
????????????????? 星期一之前的那幾天被認為是“第0周”
%z???????????? 以+HHMM或-HHMM表示的UTC時區偏移量,如果時區為naive,則返回空字符串
%F???????????? %Y-%m-%d簡寫形式,例如2012-4-18
%D??????????? %m/%d/%y簡寫形式,例如04/18/12

datetime.strptime可以?這些格式化編碼將字符串轉換為?期
value = '2016-03-02'
datetime.strptime(value, '%Y-%m-%d')??????? # 輸出:datetime.datetime(2016, 3, 2, 0, 0)

datestrs = ['5/4/2018', '8/10/2018']
[datetime.strptime(x, '%m/%d/%Y') for x in datestrs]??????? # 輸出如下:使用推導式逐個轉換
[datetime.datetime(2018, 5, 4, 0, 0), datetime.datetime(2018, 8, 10, 0, 0)]

datetime.strptime是通過已知格式進??期解析的最佳?式。但是每次都要編寫格式定義是很麻煩的事情,尤其
是對于?些常?的?期格式。這種情況下,你可以?dateutil這個第三?包中的parser.parse?法(pandas中已經
?動安裝好):
from dateutil.parser import parse
parse('2016-3-2')?????? # 輸出:datetime.datetime(2016, 3, 2, 0, 0)
dateutil可以解析?乎所有?類能夠理解的?期表示形式
parse('Jan 31, 1997 10:45 PM')????? # 輸出:datetime.datetime(1997, 1, 31, 22, 45)
在國際通?的格式中,?出現在?的前?很普遍,傳?dayfirst=True即可解決這個問題:
parse('7/8/2018', dayfirst=True)??? # 輸出:datetime.datetime(2018, 8, 7, 0, 0)

pandas通常是?于處理成組?期的,不管這些?期是DataFrame的軸索引還是列。to_datetime?法可以解析多種不同的?期表示形式。對標準?期格式(如ISO8601)的解析?常快:
datestrs = ['2018-07-10 12:00:00', '2018-10-16 00:00:00']
pd.to_datetime(datestrs)??????? # 輸出如下:
DatetimeIndex(['2018-07-10 12:00:00', '2018-10-16 00:00:00'], dtype='datetime64[ns]', freq=None)
它還可以處理缺失值(None、空字符串等):
idx = pd.to_datetime(datestrs + [None])
idx???????? # 輸出如下:
DatetimeIndex(['2018-07-10 12:00:00', '2018-10-16 00:00:00', 'NaT'], dtype='datetime64[ns]', freq=None)
idx[2]????????? # 輸出:NaT
pd.isnull(idx)????????? # 輸出:array([False, False,? True])
NaT(Not a Time)是pandas中時間戳數據的null值

注意:dateutil.parser是?個實?但不完美的?具。?如說,它會把?些原本不是?期的字符串認作是?期
(?如"42"會被解析為2042年的今天)。

datetime對象還有?些特定于當前環境(位于不同國家或使?不同語?的系統)的格式化選項。例如,德語或法語系統所?的?份簡寫就與英語系統所?的不同。表11-3進?了總結。

表11-3 特定于當前環境的?期格式
代碼????????? 說明
%a??????????? 星期幾的簡寫
%A?????????? 星期幾的全稱
%b?????????? 月份的簡寫
%B?????????? 月份的全稱
%c?????????? 完整的日期和時間,例如"Tue 01 May 2012 04:20:57 PM"
%p?????????? 不同環境中的AM或PM
%x?????????? 適合于當前環境的日期格式,例如,在USA,“May 1, 2012”會生產"05/01/2012"
%X?????????? 適合于當前環境的時間格式,例如 "04:24:12 PM"

二、時間序列基礎
pandas最基本的時間序列類型就是以時間戳(通常以Python字符串或datatime對象表示)為索引的Series:
from datetime import datetime
dates = [datetime(2011, 1, 2), datetime(2011, 1, 5),
?????????????? datetime(2011, 1, 7), datetime(2011, 1, 8),
?????????????? datetime(2011, 1, 10), datetime(2011, 1, 12)]
ts = pd.Series(np.random.randn(6), index=dates)
ts?????????????? # 輸出如下:
2011-01-02??? 0.758055
2011-01-05??? 0.197013
2011-01-07?? -1.014007
2011-01-08?? -0.083171
2011-01-10??? 1.299712
2011-01-12?? -0.799759
dtype: float64
這些datetime對象實際上是被放在?個DatetimeIndex中的:
ts.index??????????? # 輸出如下:
DatetimeIndex(['2011-01-02', '2011-01-05', '2011-01-07', '2011-01-08',
?????????????????????????? '2011-01-10', '2011-01-12'],
???????????????????????? dtype='datetime64[ns]', freq=None)
跟其他Series?樣,不同索引的時間序列之間的算術運算會?動按?期對?
ts + ts[::2]??????????? # 輸出如下:
2011-01-02??? 1.516111
2011-01-05?????????? NaN
2011-01-07?? -2.028014
2011-01-08?????????? NaN
2011-01-10??? 2.599424
2011-01-12?????????? NaN
dtype: float64
ts[::2] 是每隔兩個取?個。
pandas?NumPy的datetime64數據類型以納秒形式存儲時間戳
ts.index.dtype????????????? # 輸出:dtype('<M8[ns]')

DatetimeIndex中的各個標量值是pandas的Timestamp對象
stamp = ts.index[0]
stamp?????????? # 輸出:Timestamp('2011-01-02 00:00:00')
只要有需要,TimeStamp可以隨時?動轉換為datetime對象。此外,它還可以存儲頻率信息(如果有的話),且知道如何執?時區轉換以及其他操作。稍后將對此進?詳細講解。

1、索引、選取、?集構造
當你根據標簽索引選取數據時,時間序列和其它的pandas.Series很像:
stamp = ts.index[2]
ts[stamp]????????? # 輸出: -1.014007193261713
還有?種更為?便的?法:傳??個可以被解釋為?期的字符串
ts['1/10/2011']???????? # 輸出:1.2997122200536004
ts['20110110']?????????? # 輸出:1.2997122200536004

對于較?的時間序列,只需傳?“年”或“年?”即可輕松選取數據的切?
longer_ts = pd.Series(np.random.randn(1000),
???????????????????????????????????? index=pd.date_range('1/1/2000', periods=1000))
longer_ts?????????? # 輸出如下:
2000-01-01??? 0.297975
2000-01-02?? -1.153909
2000-01-03??? 0.090682
2000-01-04??? 0.552662
2000-01-05??? 1.635998
???????????????? ...
2002-09-22??? 0.039126
2002-09-23??? 0.379367
2002-09-24?? -0.037303
2002-09-25??? 1.009411
2002-09-26?? -0.360946
Freq: D, Length: 1000, dtype: float64
longer_ts['2001']?????????? # 輸出如下:選取的切片是一年
2001-01-01?? -0.069738
2001-01-02?? -1.858975
2001-01-03?? -0.021057
2001-01-04?? -0.928934
2001-01-05?? -1.600358
???????????????? ...
2001-12-27?? -0.133934
2001-12-28??? 0.216217
2001-12-29?? -0.888471
2001-12-30??? 0.103915
2001-12-31?? -0.128421
Freq: D, Length: 365, dtype: float64
這?,字符串“2001”被解釋成年,并根據它選取時間區間。指定?也同樣奏效
longer_ts['2001-05']??????????? # 輸出如下:選取的切片是一月
2001-05-01?? -1.132128
2001-05-02??? 0.730976
2001-05-03?? -1.047071
2001-05-04?? -0.687509
2001-05-05?? -0.618300
???????????????? ...
2001-05-27??? 0.389774
2001-05-28??? 1.751153
2001-05-29??? 0.940651
2001-05-30??? 0.631526
2001-05-31??? 0.000392
Freq: D, Length: 31, dtype: float64
datetime對象也可以進?切?
ts[datetime(2011, 1, 7):]?????? # 輸出如下:
2011-01-07?? -1.014007
2011-01-08?? -0.083171
2011-01-10??? 1.299712
2011-01-12?? -0.799759
dtype: float64
由于?部分時間序列數據都是按照時間先后排序的,因此你也可以?不存在于該時間序列中的時間戳對其進?切?(即范圍查詢):
ts????????????????? # 輸出如下:
2011-01-02??? 0.758055
2011-01-05??? 0.197013
2011-01-07?? -1.014007
2011-01-08?? -0.083171
2011-01-10??? 1.299712
2011-01-12?? -0.799759
dtype: float64
ts['1/6/2011':'1/11/2011']????????? # 輸出如下:切片的起始時間不在時間序列中
2011-01-07?? -1.014007
2011-01-08?? -0.083171
2011-01-10??? 1.299712
dtype: float64
跟之前?樣,你可以傳?字符串?期、datetime或Timestamp。注意,這樣切?所產?的是源時間序列的視圖,跟NumPy數組的切?運算是?樣的。這意味著,沒有數據被復制,對切?進?修改會反映到原始數據上。

此外,還有?個等價的實例?法也可以截取兩個?期之間TimeSeries:
ts.truncate(after='1/9/2011')?????????? # 輸出如下:實例方法truncate()
2011-01-02??? 0.758055
2011-01-05??? 0.197013
2011-01-07?? -1.014007
2011-01-08?? -0.083171
dtype: float64

這些操作對DataFrame也有效。例如,對DataFrame的?進?索引:
dates = pd.date_range('1/1/2000', periods=100, freq='W-WED')
long_df = pd.DataFrame(np.random.randn(100, 4),
???????????????????????????????????????? index=dates,
???????????????????????????????????????? columns=['Colorado', 'Texas', 'New York', 'Ohio'])
long_df.loc['5-2001']??????????? # 輸出如下:
????????????????????? Colorado?????? Texas?? New York??????? Ohio
2001-05-02 -0.439088? 0.405889 -0.758566 -1.257653
2001-05-09? 1.048846 -0.822053? 0.250146? 1.263414
2001-05-16 -1.811179? 1.282718 -0.274745 -2.329642
2001-05-23 -1.590255? 1.057494 -1.306906? 0.308010
2001-05-30 -2.094225? 0.816898 -0.576982 -0.257714

2、帶有重復索引的時間序列
在某些應?場景中,可能會存在多個觀測數據落在同?個時間點上的情況。下?就是?個例?:
dates = pd.DatetimeIndex(['1/1/2000', '1/2/2000', '1/2/2000',
????????????????????????????????????????????? '1/2/2000', '1/3/2000'])
dup_ts = pd.Series(np.arange(5), index=dates)
dup_ts????????? # 輸出如下:
2000-01-01??? 0
2000-01-02??? 1
2000-01-02??? 2
2000-01-02??? 3
2000-01-03??? 4
dtype: int32
通過檢查索引的is_unique屬性,我們就可以知道它是不是唯?的:
dup_ts.index.is_unique????????? # 輸出:False
對這個時間序列進?索引,要么產?標量值,要么產?切?,具體要看所選的時間點是否重復:
dup_ts['1/3/2000']????????? # 輸出:4,(不重復,產生標量值)
dup_ts['1/2/2000']?????????? # 輸出如下:(重復,duplicated,產生的是切片)
2000-01-02??? 1
2000-01-02??? 2
2000-01-02??? 3
dtype: int32
假設你想要對具有?唯?時間戳的數據進?聚合。?個辦法是使?groupby,并傳?level=0
grouped = dup_ts.groupby(level=0)?????? # level=0,對第1層標簽分組
grouped.mean()???????????? # 輸出如下:分組平均數
2000-01-01??? 0
2000-01-02??? 2
2000-01-03??? 4
dtype: int32
grouped.count()???????????? # 輸出如下:分組統計
2000-01-01??? 1
2000-01-02??? 3
2000-01-03??? 1
dtype: int64

三、?期的范圍、頻率以及移動
pandas中的原?時間序列?般被認為是不規則的,也就是說,它們沒有固定的頻率。對于?部分應?程序??,這是?所謂的。但是,它常常需要以某種相對固定的頻率進?分析,?如每?、每?、每15分鐘等(這樣?然會在時間序列中引?缺失值)。幸運的是,pandas有?整套標準時間序列頻率以及?于重采樣、頻率推斷、?成固定頻率?期范圍的?具。例如,我們可以將之前那個時間序列轉換為?個具有固定頻率(每?)的時間序列,只需調?resample即可:
ts????????????????????? # 現在有ts變量的內容如下:
2011-01-02?? -1.418847
2011-01-05?? -1.585231
2011-01-07??? 1.136025
2011-01-08??? 0.586130
2011-01-10?? -0.789736
2011-01-12??? 0.128133
dtype: float64
resampler = ts.resample('D')??? # 字符串“D”是每天的意思。調用resample()方法重采樣
頻率的轉換(或重采樣)是?個?較?的主題,在本篇第六小節討論。這?,先了解如何使?基本的頻率和它的倍數。

1、?成?期范圍
pandas.date_range可?于根據指定的頻率?成指定?度的DatetimeIndex
index = pd.date_range('2012-4-1', '2012-6-1')?????? # 日期范圍。默認按天計算時間點
index?????????????? # 輸出如下:
DatetimeIndex(['2012-04-01', '2012-04-02', '2012-04-03', '2012-04-04',
?????????????????????????? '2012-04-05', '2012-04-06', '2012-04-07', '2012-04-08',
?????????????????????????? '2012-04-09', '2012-04-10', '2012-04-11', '2012-04-12',
?????????????????????????? '2012-04-13', '2012-04-14', '2012-04-15', '2012-04-16',
?????????????????????????? '2012-04-17', '2012-04-18', '2012-04-19', '2012-04-20',
?????????????????????????? '2012-04-21', '2012-04-22', '2012-04-23', '2012-04-24',
?????????????????????????? '2012-04-25', '2012-04-26', '2012-04-27', '2012-04-28',
?????????????????????????? '2012-04-29', '2012-04-30', '2012-05-01', '2012-05-02',
?????????????????????????? '2012-05-03', '2012-05-04', '2012-05-05', '2012-05-06',
?????????????????????????? '2012-05-07', '2012-05-08', '2012-05-09', '2012-05-10',
?????????????????????????? '2012-05-11', '2012-05-12', '2012-05-13', '2012-05-14',
?????????????????????????? '2012-05-15', '2012-05-16', '2012-05-17', '2012-05-18',
?????????????????????????? '2012-05-19', '2012-05-20', '2012-05-21', '2012-05-22',
?????????????????????????? '2012-05-23', '2012-05-24', '2012-05-25', '2012-05-26',
?????????????????????????? '2012-05-27', '2012-05-28', '2012-05-29', '2012-05-30',
?????????????????????????? '2012-05-31', '2012-06-01'],
?????????????????????????? dtype='datetime64[ns]', freq='D')
默認情況下,date_range會產?按天計算的時間點。如果只傳?起始或結束?期,那就還得傳??個表示?段時間的數字
pd.date_range(start='2012-4-1', periods=20)???????? # 輸出如下:按天計算,向前計算20天
DatetimeIndex(['2012-04-01', '2012-04-02', '2012-04-03', '2012-04-04',
?????????????????????????? '2012-04-05', '2012-04-06', '2012-04-07', '2012-04-08',
?????????????????????????? '2012-04-09', '2012-04-10', '2012-04-11', '2012-04-12',
?????????????????????????? '2012-04-13', '2012-04-14', '2012-04-15', '2012-04-16',
?????????????????????????? '2012-04-17', '2012-04-18', '2012-04-19', '2012-04-20'],
???????????????????????? dtype='datetime64[ns]', freq='D')
pd.date_range(end='2012-6-1', periods=20)?????????? # 輸出如下:按天計算,向后計算20天
DatetimeIndex(['2012-05-13', '2012-05-14', '2012-05-15', '2012-05-16',
????????????????????????? '2012-05-17', '2012-05-18', '2012-05-19', '2012-05-20',
????????????????????????? '2012-05-21', '2012-05-22', '2012-05-23', '2012-05-24',
????????????????????????? '2012-05-25', '2012-05-26', '2012-05-27', '2012-05-28',
????????????????????????? '2012-05-29', '2012-05-30', '2012-05-31', '2012-06-01'],
????????????????????? dtype='datetime64[ns]', freq='D')
起始和結束?期定義了?期索引的嚴格邊界。例如,如果你想要?成?個由每?最后?個?作?組成的?期索引,可以傳?"BM"頻率(表示business end of month,表11-4是頻率列表),這樣就只會包含時間間隔內(或剛好在邊界上的)符合頻率要求的?期:
pd.date_range('2000-1-1', '2001-1-1', freq='BM')??????? # 輸出如下:頻率是每月最后一個工作日
DatetimeIndex(['2000-01-31', '2000-02-29', '2000-03-31', '2000-04-28',
????????????????????????? '2000-05-31', '2000-06-30', '2000-07-31', '2000-08-31',
????????????????????????? '2000-09-29', '2000-10-31', '2000-11-30', '2000-12-29'],
???????????????????????? dtype='datetime64[ns]', freq='BM')

表11-4 基本的時間序列頻率(不完整)(下面的頻率用于date_range()函數的freq參數)


date_range默認會保留起始和結束時間戳的時間信息(如果有的話):
pd.date_range('2016-3-2 8:30:15', periods=5)??????????????? # 輸出如下:注意默認的頻率是天('D')
DatetimeIndex(['2016-03-02 08:30:15', '2016-03-03 08:30:15',
????????????????????????? '2016-03-04 08:30:15', '2016-03-05 08:30:15',
????????????????????????? '2016-03-06 08:30:15'],
???????????????????????? dtype='datetime64[ns]', freq='D')
有時,雖然起始和結束?期帶有時間信息,但你希望產??組被規范化(normalize)到午夜的時間戳。normalize選項即可實現該功能
pd.date_range('2016-3-2 8:30:15', periods=5, normalize=True)??????????? # 規范化的時間戳顯示:
DatetimeIndex(['2016-03-02', '2016-03-03', '2016-03-04', '2016-03-05',
????????????????????????? '2016-03-06'],
???????????????????????? dtype='datetime64[ns]', freq='D')

2、頻率和?期偏移量
pandas中的頻率是由?個基礎頻率(base frequency)和?個乘數組成的基礎頻率通常以?個字符串別名表示,?如"M"表示每?,"H"表示每?時。對于每個基礎頻率,都有?個被稱為?期偏移量(date offset)的對象與之對應。例如,按?時計算的頻率可以?Hour類表示:
from pandas.tseries.offsets import Hour, Minute
hour = Hour()
hour??????? # 輸出hour對象: <Hour>
傳??個整數即可定義偏移量的倍數:
four_hours = Hour(4)
four_hours????????????? # 輸出: <4 * Hours>
?般來說,?需明確創建這樣的對象,只需使?諸如"H"或"4H"這樣的字符串別名即可。在基礎頻率前?放上?個整數即可創建倍數
pd.date_range('2018-1-1', '2018-1-3 23:59', freq='4h')????? # 輸出如下:
DatetimeIndex(['2018-01-01 00:00:00', '2018-01-01 04:00:00',
????????????????????????? '2018-01-01 08:00:00', '2018-01-01 12:00:00',
????????????????????????? '2018-01-01 16:00:00', '2018-01-01 20:00:00',
????????????????????????? '2018-01-02 00:00:00', '2018-01-02 04:00:00',
????????????????????????? '2018-01-02 08:00:00', '2018-01-02 12:00:00',
????????????????????????? '2018-01-02 16:00:00', '2018-01-02 20:00:00',
????????????????????????? '2018-01-03 00:00:00', '2018-01-03 04:00:00',
????????????????????????? '2018-01-03 08:00:00', '2018-01-03 12:00:00',
????????????????????????? '2018-01-03 16:00:00', '2018-01-03 20:00:00'],
???????????????????????? dtype='datetime64[ns]', freq='4H')

?部分偏移量對象都可通過加法進?連接
Hour(2) + Minute(30)??????????????? # 輸出:<150 * Minutes>
同理,你也可以傳?頻率字符串(如"2h30min"),這種字符串可以被?效地解析為等效的表達式:
pd.date_range('2018-1-1', periods=10, freq='1h30min')?????? # 輸出如下:
DatetimeIndex(['2018-01-01 00:00:00', '2018-01-01 01:30:00',
????????????????????????? '2018-01-01 03:00:00', '2018-01-01 04:30:00',
????????????????????????? '2018-01-01 06:00:00', '2018-01-01 07:30:00',
????????????????????????? '2018-01-01 09:00:00', '2018-01-01 10:30:00',
????????????????????????? '2018-01-01 12:00:00', '2018-01-01 13:30:00'],
??????????????????????? dtype='datetime64[ns]', freq='90T')

有些頻率所描述的時間點并不是均勻分隔的。例如,"M"(?歷?末)和"BM"(每?最后?個?作?)就取決于每?的天數,對于后者,還要考慮?末是不是周末。由于沒有更好的術語,我將這些稱為錨點偏移量(anchored offset)。
表11-4列出了pandas中的頻率代碼和?期偏移量類。
可根據實際需求?定義?些頻率類以便提供pandas所沒有的?期邏輯。

表11-4 時間序列的基礎頻率

3、WOM?期
WOM(Week Of Month)是?種?常實?的頻率類,它以WOM開頭。它使你能獲得諸如“每?第3個星期五”之類的?期:
rng = pd.date_range('2018-1-1', '2018-9-1', freq='WOM-3FRI')????? # 每月第三個星期五
list(rng)?????????????????????????? # 輸出如下:
[Timestamp('2018-01-19 00:00:00', freq='WOM-3FRI'),
? Timestamp('2018-02-16 00:00:00', freq='WOM-3FRI'),
? Timestamp('2018-03-16 00:00:00', freq='WOM-3FRI'),
? Timestamp('2018-04-20 00:00:00', freq='WOM-3FRI'),
? Timestamp('2018-05-18 00:00:00', freq='WOM-3FRI'),
? Timestamp('2018-06-15 00:00:00', freq='WOM-3FRI'),
? Timestamp('2018-07-20 00:00:00', freq='WOM-3FRI'),
? Timestamp('2018-08-17 00:00:00', freq='WOM-3FRI')]

4、移動(超前和滯后)數據
移動(shifting)指的是沿著時間軸將數據前移或后移。Series和DataFrame都有?個shift?法?于執?單純的前移或后移操作,保持索引不變
ts = pd.Series(np.random.randn(4),
?????????????????????? index=pd.date_range('1/1/2000', periods=4, freq='M'))
ts?????????????????????? # 輸出如下:
2000-01-31?? -0.832222
2000-02-29??? 0.341062
2000-03-31?? -1.939174
2000-04-30??? 0.861032
Freq: M, dtype: float64
ts.shift(2)???????????? # 輸出如下:沿時間軸將數據向前移動
2000-01-31?????????? NaN
2000-02-29?????????? NaN
2000-03-31?? -0.832222
2000-04-30??? 0.341062
Freq: M, dtype: float64
ts.shift(-2)?????????? # 輸出如下:沿時間軸將數據向后移動
2000-01-31?? -1.939174
2000-02-29???? 0.861032
2000-03-31??????????? NaN
2000-04-30??????????? NaN
Freq: M, dtype: float64
當我們這樣進?移動時,就會在時間序列的前?或后?產?缺失數據

shift通常?于計算?個時間序列或多個時間序列(如DataFrame的列)中的百分?變化。可以這樣表達:
ts / ts.shift(1) - 1

由于單純的移位操作不會修改索引,所以部分數據會被丟棄。因此,如果頻率已知,則可以將其傳給shift以便實現對時間戳進?位移?不是對數據進?簡單位移:
ts.shift(2, freq='M')?????????????? # 輸出如下:已知頻率的情況,對時間戳進行位移
2000-03-31?? -0.832222
2000-04-30??? 0.341062
2000-05-31?? -1.939174
2000-06-30??? 0.861032
Freq: M, dtype: float64
這?還可以使?其他頻率,于是就能?常靈活地對數據進?超前和滯后處理
ts.shift(3, freq='D')?????????????? # 輸出如下:向前移3天
2000-02-03?? -0.832222
2000-03-03??? 0.341062
2000-04-03?? -1.939174
2000-05-03??? 0.861032
dtype: float64
ts.shift(1, freq='90T')???????????? # 輸出如下:向前移動90分鐘
2000-01-31 01:30:00?? -0.832222
2000-02-29 01:30:00??? 0.341062
2000-03-31 01:30:00?? -1.939174
2000-04-30 01:30:00??? 0.861032
Freq: M, dtype: float64

5、通過偏移量對?期進?位移
pandas的?期偏移量還可以?在datetime或Timestamp對象上:
from pandas.tseries.offsets import Day, MonthEnd
now = datetime(2011, 11, 17)
now + 3 * Day()???????? # 輸出如下:時間戳,使用now + Day(3)是一樣的結果
Timestamp('2011-11-20 00:00:00')

如果加的是錨點偏移量(?如MonthEnd),第?次增量會將原?期向前滾動到符合頻率規則的下?個?期:
now + MonthEnd()???????? # 輸出如下:MonthEnd是偏移到每月的最后一天
Timestamp('2011-11-30 00:00:00')
now + MonthEnd(2)??????? # 輸出如下:
Timestamp('2011-12-31 00:00:00')

通過錨點偏移量的rollforward和rollback?法,可明確地將?期向前或向后“滾動”:
offset = MonthEnd()
offset.rollforward(now)??????????????? # 輸出如下:將now對應的日期向前滾動到月末
Timestamp('2011-11-30 00:00:00')
offset.rollback(now)??????????????? # 輸出如下:將now對應的日期向后滾動到上一個月的月末
Timestamp('2011-10-31 00:00:00')

?期偏移量還有?個巧妙的?法,即結合groupby使?這兩個“滾動”?法
ts = pd.Series(np.random.randn(20),
??????????????????????? index=pd.date_range('1/15/2000', periods=20, freq='4D'))
ts?????????????????????? # 輸出如下:
2000-01-15?? -0.476511
2000-01-19??? 0.646956
2000-01-23??? 0.157716
2000-01-27?? -1.207581
2000-01-31?? -0.629533
???????????????? ...
2000-03-15??? 0.082505
2000-03-19?? -0.154366
2000-03-23??? 1.368601
2000-03-27?? -2.117017
2000-03-31?? -1.594271
Freq: 4D, Length: 20, dtype: float64
ts.groupby(offset.rollforward).mean()????? # 輸出如下:由于offset.rollforward指向月末,計算每月的平均數
2000-01-31?? -0.301791
2000-02-29?? -0.001096
2000-03-31?? -0.129890
dtype: float64
當然,更簡單、更快速地實現該功能的辦法是使?resample(后面六?節詳細介紹):
ts.resample('M').mean()????????????? # 輸出如下:
2000-01-31?? -0.301791
2000-02-29?? -0.001096
2000-03-31?? -0.129890
Freq: M, dtype: float64

四、時區處理
時間序列處理?作中最讓?不爽的就是對時區的處理。許多?都選擇以世界標準時間(UTC,它是格林威治標準時間(Greenwich Mean Time)的接替者,?前已經是國際標準了)來處理時間序列。時區是以UTC偏移量的形式表示的。例如,夏令時期間,紐約?UTC慢4?時,?在全年其他時間則?UTC慢5?時。

在Python中,時區信息來?第三?庫pytz,它使Python可以使?Olson數據庫(匯編了世界時區信息)。這對歷史數據?常重要,這是因為由于各地政府的各種突發奇想,夏令時轉變?期(甚?UTC偏移量)已經發?過多次改變了。就拿美國來說,DST轉變時間?1900年以來就改變過多次!

有關pytz庫的更多信息,可查閱其?檔。由于pandas包裝了pytz的功能,因此可不?記憶其API,只要記得時區的名稱即可。時區名可以在shell中看到,也可以通過?檔查看:
import pytz
pytz.common_timezones[-5:]????????? # 輸出如下:
['US/Eastern', 'US/Hawaii', 'US/Mountain', 'US/Pacific', 'UTC']
要從pytz中獲取時區對象,使?pytz.timezone即可
tzz = pytz.timezone('Asia/Shanghai')
tzz???????? # 輸出: <DstTzInfo 'Asia/Shanghai' LMT+8:06:00 STD>
pandas中的?法既可以接受時區名也可以接受這些對象

1、時區本地化和轉換
默認情況下,pandas中的時間序列是單純的(naive)時區。看看下?這個時間序列:
rng = pd.date_range('3/9/2012 9:30', periods=6, freq='D')
ts = pd.Series(np.random.randn(len(rng)), index=rng)
ts????????????????????? # 輸出如下:
2012-03-09 09:30:00?? -0.604688
2012-03-10 09:30:00?? -0.824233
2012-03-11 09:30:00?? -1.376939
2012-03-12 09:30:00??? 0.660257
2012-03-13 09:30:00?? -0.362623
2012-03-14 09:30:00?? -1.885881
Freq: D, dtype: float64
其索引的tz字段為None
print(ts.index.tz)????????????????? # 輸出:None
可以?時區集?成?期范圍
pd.date_range('3/9/2012 9:30', periods=10, freq='D', tz='UTC')????????? # 輸出如下:
DatetimeIndex(['2012-03-09 09:30:00+00:00', '2012-03-10 09:30:00+00:00',
????????????????????????? '2012-03-11 09:30:00+00:00', '2012-03-12 09:30:00+00:00',
????????????????????????? '2012-03-13 09:30:00+00:00', '2012-03-14 09:30:00+00:00',
????????????????????????? '2012-03-15 09:30:00+00:00', '2012-03-16 09:30:00+00:00',
????????????????????????? '2012-03-17 09:30:00+00:00', '2012-03-18 09:30:00+00:00'],
???????????????????????? dtype='datetime64[ns, UTC]', freq='D')

從單純到本地化的轉換是通過tz_localize?法處理的:
ts????????????????????? # 有ts如下:
2012-03-09 09:30:00?? -0.604688
2012-03-10 09:30:00?? -0.824233
2012-03-11 09:30:00?? -1.376939
2012-03-12 09:30:00??? 0.660257
2012-03-13 09:30:00?? -0.362623
2012-03-14 09:30:00?? -1.885881
Freq: D, dtype: float64
ts_utc = ts.tz_localize('UTC')
ts_utc????????????????? # 輸出如下:
2012-03-09 09:30:00+00:00?? -0.604688
2012-03-10 09:30:00+00:00?? -0.824233
2012-03-11 09:30:00+00:00?? -1.376939
2012-03-12 09:30:00+00:00??? 0.660257
2012-03-13 09:30:00+00:00?? -0.362623
2012-03-14 09:30:00+00:00?? -1.885881
Freq: D, dtype: float64
ts_utc.index??????????? # 輸出如下:
DatetimeIndex(['2012-03-09 09:30:00+00:00', '2012-03-10 09:30:00+00:00',
?????????????????????????? '2012-03-11 09:30:00+00:00', '2012-03-12 09:30:00+00:00',
?????????????????????????? '2012-03-13 09:30:00+00:00', '2012-03-14 09:30:00+00:00'],
???????????????????????? dtype='datetime64[ns, UTC]', freq='D')
?旦時間序列被本地化到某個特定時區,就可以?tz_convert將其轉換到別的時區了:
ts_utc.tz_convert('Asia/Shanghai')????????????? # 輸出省略
ts_utc.tz_convert('America/New_York')?????????? # 輸出如下:
2012-03-09 04:30:00-05:00?? -0.604688
2012-03-10 04:30:00-05:00?? -0.824233
2012-03-11 05:30:00-04:00?? -1.376939
2012-03-12 05:30:00-04:00??? 0.660257
2012-03-13 05:30:00-04:00?? -0.362623
2012-03-14 05:30:00-04:00?? -1.885881
Freq: D, dtype: float64
對于上?這種時間序列(它跨越了美國東部時區的夏令時轉變期),我們可以將其本地化到EST,然后轉換為UTC或柏林時間:
ts_eastern = ts.tz_localize('America/New_York')????? # tz_localize()從本地轉換到指定時區
ts_eastern.tz_convert('UTC')???????????????????? # 輸出如下:轉換為UTC時間
2012-03-09 14:30:00+00:00?? -0.604688
2012-03-10 14:30:00+00:00?? -0.824233
2012-03-11 13:30:00+00:00?? -1.376939
2012-03-12 13:30:00+00:00??? 0.660257
2012-03-13 13:30:00+00:00?? -0.362623
2012-03-14 13:30:00+00:00?? -1.885881
Freq: D, dtype: float64
ts_eastern.tz_convert('Europe/Berlin')????????? # 輸出如下:轉換為柏林時間
2012-03-09 15:30:00+01:00?? -0.604688
2012-03-10 15:30:00+01:00?? -0.824233
2012-03-11 14:30:00+01:00?? -1.376939
2012-03-12 14:30:00+01:00??? 0.660257
2012-03-13 14:30:00+01:00?? -0.362623
2012-03-14 14:30:00+01:00?? -1.885881
Freq: D, dtype: float64

tz_localize和tz_convert也是DatetimeIndex的實例?法
ts.index.tz_localize('Asia/Shanghai')?????????? # 將ts.index的時間序列本地化為上海時間
DatetimeIndex(['2012-03-09 09:30:00+08:00', '2012-03-10 09:30:00+08:00',
?????????????????????????? '2012-03-11 09:30:00+08:00', '2012-03-12 09:30:00+08:00',
?????????????????????????? '2012-03-13 09:30:00+08:00', '2012-03-14 09:30:00+08:00'],
???????????????????????? dtype='datetime64[ns, Asia/Shanghai]', freq='D')
注意:對單純時間戳的本地化操作還會檢查夏令時轉變期附近容易混淆或不存在的時間。

2、操作時區意識型Timestamp對象(時區操作--已知時間戳對象)
跟時間序列和?期范圍差不多,獨?的Timestamp對象也能被從單純型(naive)本地化為已知時區(time zone-aware),并從?個時區轉換到另?個時區:
stamp = pd.Timestamp('2011-03-12 04:00')
stamp_utc = stamp.tz_localize('utc')??????????? # 本地化為已知時區
stamp_utc.tz_convert('America/New_York')???????? # 輸出如下:轉換為紐約時間
Timestamp('2011-03-11 23:00:00-0500', tz='America/New_York')

已知時區Timestamp對象在內部保存了?個UTC時間戳值(?UNIX紀元(1970年1?1?)算起的納秒數)。這個UTC值在時區轉換過程中是不會發?變化的:
stamp_utc.value???????? # 輸出:1299902400000000000
stamp_utc.tz_convert('America/New_York').value????????????? # 輸出:1299902400000000000

當使?pandas的DateOffset對象執?時間算術運算時,運算過程會?動關注是否存在夏令時轉變期。這?,我們創建了在DST轉變之前的時間戳。?先,來看夏令時轉變前的30分鐘:
from pandas.tseries.offsets import Hour
stamp = pd.Timestamp('2012-3-12 01:30', tz='US/Eastern')
stamp?????????????????? # 輸出:Timestamp('2012-03-12 01:30:00-0400', tz='US/Eastern')
stamp + Hour()????????? # 輸出如下:
Timestamp('2012-03-12 02:30:00-0400', tz='US/Eastern')
然后,夏令時轉變前90分鐘:
stamp = pd.Timestamp('2012-11-04 00:30', tz='US/Eastern')
stamp?????????????????? # 輸出如下:
Timestamp('2012-11-04 00:30:00-0400', tz='US/Eastern')
stamp + 2 * Hour()????? # 輸出如下:
Timestamp('2012-11-04 01:30:00-0500', tz='US/Eastern')

3、不同時區之間的運算
如果兩個時間序列的時區不同,在將它們合并到?起時,最終結果就會是UTC。由于時間戳其實是以UTC存儲的,所以這是?個很簡單的運算,并不需要發?任何轉換:
rng = pd.date_range('3/7/2012 9:30', periods=10, freq='B')
ts = pd.Series(np.random.randn(len(rng)), index=rng)
ts????????????????????? # 輸出如下:
2012-03-07 09:30:00?? -2.376522
2012-03-08 09:30:00?? -0.666842
2012-03-09 09:30:00?? -0.261704
2012-03-12 09:30:00?? -0.552518
2012-03-13 09:30:00?? -0.595424
2012-03-14 09:30:00??? 0.055178
2012-03-15 09:30:00?? -0.147100
2012-03-16 09:30:00??? 0.150247
2012-03-19 09:30:00??? 1.349859
2012-03-20 09:30:00??? 0.235983
Freq: B, dtype: float64
ts1 = ts[:7].tz_localize('Europe/London')????? # 本地化時區為歐洲倫敦時區
ts2 = ts1[2:].tz_convert('Europe/Moscow')??? # 反轉為莫斯科時區
result = ts1 + ts2
result.index??????????? # 輸出如下:結果時區為UTC
DatetimeIndex(['2012-03-07 09:30:00+00:00', '2012-03-08 09:30:00+00:00',
?????????????????????????? '2012-03-09 09:30:00+00:00', '2012-03-12 09:30:00+00:00',
?????????????????????????? '2012-03-13 09:30:00+00:00', '2012-03-14 09:30:00+00:00',
?????????????????????????? '2012-03-15 09:30:00+00:00'],
???????????????????????? dtype='datetime64[ns, UTC]', freq='B')

五、時期及其算術運算
時期(period)表示的是時間區間,?如數?、數?、數季、數年等。Period類所表示的就是這種數據類型,其構造函數需要?到?個字符串或整數,以及表11-4中的頻率:
p = pd.Period(2007, freq='A-DEC')?????????????? # 參數A-DEC指向每年第12月的最后一天
p?????????? # 輸出:Period('2007', 'A-DEC')
這?,這個Period對象表示的是從2007年1?1?到2007年12?31?之間的整段時間。只需對Period對象加上或減去?個整數即可達到根據其頻率進?位移的效果:
p?????????? # 輸出:Period('2007', 'A-DEC')
p + 5?????? # 輸出:Period('2012', 'A-DEC'),加5年
p - 2??????? # 輸出:Period('2005', 'A-DEC'),減2年
如果兩個Period對象擁有相同的頻率,則它們的差就是它們之間的單位數量:
pd.Period('2014', freq='A-DEC') - p???????????? # 輸出:7,表示相差7年

period_range函數可?于創建規則的時期范圍
rng = pd.period_range('2000-1-1', '2000-6-30', freq='M')
rng???????? # 輸出如下:
PeriodIndex(['2000-01', '2000-02', '2000-03', '2000-04', '2000-05', '2000-06'], dtype='period[M]', freq='M')
PeriodIndex類保存了?組Period,它可以在任何pandas數據結構中被?作軸索引:
pd.Series(np.random.randn(len(rng)), index=rng)???????????? # 輸出如下:
2000-01?? -0.301482
2000-02??? 0.410068
2000-03??? 1.628897
2000-04??? 0.555670
2000-05?? -1.277706
2000-06??? 0.424157
Freq: M, dtype: float64
如果你有?個字符串數組,你也可以使?PeriodIndex類
values = ['2001Q3', '2002Q2', '2003Q1']
index = pd.PeriodIndex(values, freq='Q-DEC')?????? # 對字符串數組使用PeriodIndex類
index?????????????????? # 輸出如下:
PeriodIndex(['2001Q3', '2002Q2', '2003Q1'], dtype='period[Q-DEC]', freq='Q-DEC')

1、時期的頻率轉換
Period和PeriodIndex對象都可以通過其asfreq?法被轉換成別的頻率。假設我們有?個年度時期,希望將其轉換
為當年年初或年末的?個?度時期。該任務?常簡單:
p = pd.Period('2007', freq='A-DEC')
p?????????? # 輸出如下:Period('2007', 'A-DEC')
p.asfreq('M', how='start')????????? # 輸出:Period('2007-01', 'M')
p.asfreq('M', how='end')??????????? # 輸出:Period('2007-12', 'M')
你可以將Period('2007','A-DEC')看做?個被劃分為多個?度時期的時間段中的游標。圖11-1對此進?了說明。


??????????????????????????????????????????? 圖11-1? Period頻率轉換示例
對于?個不以12?結束的財政年度,?度?時期的歸屬情況就不?樣了:
p = pd.Period('2007', freq='A-JUN')
p?????????????????????? # 輸出:Period('2007', 'A-JUN')
p.asfreq('M', how='start')????????? # 輸出:Period('2006-07', 'M'),跨年
p.asfreq('M', how='end')??????????? # 輸出:Period('2007-06', 'M')

在將?頻率轉換為低頻率時,父時期(superperiod)是由?時期(subperiod)所屬的位置決定的。例如,在A-JUN頻率中,?份“2007年8?”實際上是屬于周期“2008年”的:
p = pd.Period('Aug-2007', 'M')
p.asfreq('A-JUN')?????????????????? # 輸出:Period('2008', 'A-JUN'),周期是2008年

完整的PeriodIndex或TimeSeries的頻率轉換?式也是如此:
rng = pd.period_range('2006', '2009', freq='A-DEC')
ts = pd.Series(np.random.randn(len(rng)), index=rng)
ts????????????????????? # 輸出如下:(頻率是每年最后一個月)
2006?? -0.634701
2007?? -1.254044
2008?? -1.077110
2009??? 0.887097
Freq: A-DEC, dtype: float64
ts.asfreq('M', how='start')???????? # 輸出如下:(頻率是每年最第一個月)
2006-01?? -0.634701
2007-01?? -1.254044
2008-01?? -1.077110
2009-01??? 0.887097
Freq: M, dtype: float64
這?,根據年度時期的第?個?,每年的時期被取代為每?的時期。如果我們想要每年的最后?個?作?,我們可以使?“B”頻率,并指明想要該時期的末尾:
ts.asfreq('B', how='end')?????????????????????? # 輸出如下:
2006-12-29?? -0.634701
2007-12-31?? -1.254044
2008-12-31?? -1.077110
2009-12-31??? 0.887097
Freq: B, dtype: float64

2、按季度計算的時期頻率
季度型數據在會計、?融等領域中很常?。許多季度型數據都會涉及“財年末”的概念,通常是?年12個?中某?的最后?個?歷?或?作?。就這?點來說,時期"2012Q4"根據財年末的不同會有不同的含義。pandas?持12種可能的季度型頻率,即Q-JAN到Q-DEC:
p = pd.Period('2012Q4', freq='Q-JAN')?????????? # 財年末是1月的最后一天
p?????????? # 輸出:Period('2012Q4', 'Q-JAN')
在以1?結束的財年中,2012Q4是從11?到1?(將其轉換為?型頻率就明?了)。圖11-2對此進?了說明:


??????????????????????????????????????? 圖11-2? 不同季度型頻率之間的轉換
p.asfreq('D', 'start')????????????? # 輸出如下:財年的第一天(參數傳遞方式:位置參數)
Period('2011-11-01', 'D')
p.asfreq('D', 'end')??????????????? # 輸出如下:指向財年末的最后一天
Period('2012-01-31', 'D')

因此,Period之間的算術運算會?常簡單。例如,要獲取該季度倒數第?個?作?下午4點的時間戳,你可以這樣:
# 參數傳遞方式:簡寫的位置參數。asfreq('T', 's')的頻率是分,所以16*60指向下午的16點整
p4pm = (p.asfreq('B', 'e') -1).asfreq('T', 's') + 16*60
p4pm??????????????????? # 輸出:Period('2012-01-30 16:00', 'T')
p4pm.to_timestamp()???????????????? # 輸出:Timestamp('2012-01-30 16:00:00')

period_range可?于?成季度型范圍。季度型范圍的算術運算也跟上?是?樣的:
rng = pd.period_range('2011Q3', '2012Q4', freq='Q-JAN')
ts = pd.Series(np.arange(len(rng)), index=rng)
ts????????????????????? # 輸出如下:
2011Q3??? 0
2011Q4??? 1
2012Q1??? 2
2012Q2??? 3
2012Q3??? 4
2012Q4??? 5
Freq: Q-JAN, dtype: int32
new_rng = (rng.asfreq('B', 'e') - 1).asfreq('T', 's') + 16*60?????????? # 頻率轉換
ts.index = new_rng.to_timestamp()?? # 改變ts的索引
ts????????????????????? # 輸出如下:
2010-10-28 16:00:00??? 0
2011-01-28 16:00:00??? 1
2011-04-28 16:00:00??? 2
2011-07-28 16:00:00??? 3
2011-10-28 16:00:00??? 4
2012-01-30 16:00:00??? 5
dtype: int32

3、將Timestamp轉換為Period(及其反向過程)
通過使?to_period?法,可以將由時間戳索引的Series和DataFrame對象轉換為以時期索引:
rng = pd.date_range('2000-1-1', periods=3, freq='M')
ts = pd.Series(np.random.randn(3), index=rng)
ts????????????????????? # 輸出如下:
2000-01-31??? 0.620808
2000-02-29??? 0.242898
2000-03-31??? 0.480687
Freq: M, dtype: float64
pts = ts.to_period()??? # Timestamp轉換為Period
pts
2000-01??? 0.620808
2000-02??? 0.242898
2000-03??? 0.480687
Freq: M, dtype: float64

由于時期指的是?重疊時間區間,因此對于給定的頻率,?個時間戳只能屬于?個時期新PeriodIndex的頻率默認是從時間戳推斷?來的,你也可以指定任何別的頻率。結果中允許存在重復時期
rng = pd.date_range('1/29/2000', periods=6, freq='D')

ts2 = pd.Series(np.random.randn(6), index=rng)

ts2???????????????????? # 輸出如下:
2000-01-29?? -0.012140
2000-01-30?? -0.950665
2000-01-31?? -0.197126
2000-02-01??? 0.551863
2000-02-02??? 0.813741
2000-02-03??? 0.646920
Freq: D, dtype: float64

ts2.to_period('M')????????????????? # 輸出如下:通過to_period()方法將時間戳轉換為月
2000-01?? -0.012140
2000-01?? -0.950665
2000-01?? -0.197126
2000-02??? 0.551863
2000-02??? 0.813741
2000-02??? 0.646920
Freq: M, dtype: float64

要轉換回時間戳,使?to_timestamp即可:
pts = ts2.to_period()
pts???????????????????? # 輸出如下:
2000-01-29?? -0.012140
2000-01-30?? -0.950665
2000-01-31?? -0.197126
2000-02-01??? 0.551863
2000-02-02??? 0.813741
2000-02-03??? 0.646920
Freq: D, dtype: float64

pts.to_timestamp(how='end')???????? # 輸出如下:
2000-01-29?? -0.012140
2000-01-30?? -0.950665
2000-01-31?? -0.197126
2000-02-01??? 0.551863
2000-02-02??? 0.813741
2000-02-03??? 0.646920
Freq: D, dtype: float64

4、通過數組創建PeriodIndex
固定頻率的數據集通常會將時間信息分開存放在多個列中。例如,在下?這個宏觀經濟數據集中,年度和季度
分別存放在不同的列中:
data = pd.read_csv('examples/macrodata.csv')
data.head()???????????? # 輸出如下:
???????? year? quarter?? realgdp? realcons?? realinv?? realgovt?? realdpi??? cpi??? \
0? 1959.0???????? 1.0? 2710.349??? 1707.4? 286.898?? 470.045?? 1886.9? 28.98
1? 1959.0???????? 2.0? 2778.801??? 1733.7? 310.859?? 481.301?? 1919.7? 29.15
2? 1959.0???????? 3.0? 2775.488??? 1751.8? 289.226?? 491.260?? 1916.4? 29.35
3? 1959.0???????? 4.0? 2785.204??? 1753.7? 299.356?? 484.052?? 1931.3? 29.37
4? 1960.0???????? 1.0? 2847.699??? 1770.5? 331.722?? 462.199?? 1955.5? 29.54
??????? m1? tbilrate? unemp??????? pop?? infl? realint
0? 139.7?????? 2.82??????? 5.8? 177.146? 0.00???? 0.00
1? 141.7?????? 3.08??????? 5.1? 177.830? 2.34???? 0.74
2? 140.5?????? 3.82??????? 5.3? 178.657? 2.74???? 1.09
3? 140.0?????? 4.33??????? 5.6? 179.386? 0.27???? 4.06
4? 139.6?????? 3.50??????? 5.2? 180.007? 2.31???? 1.19
data.year?????????????? # 輸出如下:
0????? 1959.0
1????? 1959.0
2????? 1959.0
3????? 1959.0
4????? 1960.0
???????? ...
198??? 2008.0
199??? 2008.0
200??? 2009.0
201??? 2009.0
202??? 2009.0
Name: year, Length: 203, dtype: float64

data.quarter??????????? # 輸出如下:
0????? 1.0
1????? 2.0
2????? 3.0
3????? 4.0
4????? 1.0
?????? ...
198??? 3.0
199??? 4.0
200??? 1.0
201??? 2.0
202??? 3.0
Name: quarter, Length: 203, dtype: float64

通過將這些數組以及?個頻率傳?PeriodIndex,就可以將它們合并成DataFrame的?個索引:
index = pd.PeriodIndex(year=data.year, quarter=data.quarter, freq='Q-DEC')
index?????????????????? # 輸出如下:
PeriodIndex(['1959Q1', '1959Q2', '1959Q3', '1959Q4', '1960Q1', '1960Q2',
?????????????????????? '1960Q3', '1960Q4', '1961Q1', '1961Q2',
???????????????????????????????????? ...
?????????????????????? '2007Q2', '2007Q3', '2007Q4', '2008Q1', '2008Q2', '2008Q3',
?????????????????????? '2008Q4', '2009Q1', '2009Q2', '2009Q3'],
????????????????????? dtype='period[Q-DEC]', length=203, freq='Q-DEC')

data.index = index
data.infl?????????????? # 輸出如下:(輸出data的infl列)
1959Q1??? 0.00
1959Q2??? 2.34
1959Q3??? 2.74
1959Q4??? 0.27
1960Q1??? 2.31
?????????? ...
2008Q3?? -3.16
2008Q4?? -8.79
2009Q1??? 0.94
2009Q2??? 3.37
2009Q3??? 3.56
Freq: Q-DEC, Name: infl, Length: 203, dtype: float64

六、重采樣及頻率轉換
重采樣(resampling)指的是將時間序列從?個頻率轉換到另?個頻率的處理過程。將?頻率數據聚合到低頻率稱為降采樣(downsampling),?將低頻率數據轉換到?頻率則稱為升采樣(upsampling)。并不是所有的重采樣都能被劃分到這兩個?類中。例如,將W-WED(每周三)轉換為W-FRI既不是降采樣也不是升采樣。

pandas對象都帶有?個resample?法,它是各種頻率轉換?作的主?函數。resample有?個類似于groupby的API,調?resample可以分組數據,然后會調??個聚合函數:
rng = pd.date_range('2000-1-1', periods=100, freq='D')
ts = pd.Series(np.random.randn(len(rng)), index=rng)

ts????????????????????????????????? # 輸出如下:
2000-01-01?? -0.222942
2000-01-02??? 0.026890
2000-01-03?? -0.233215
2000-01-04?? -0.090225
2000-01-05?? -1.650894
???????????????? ...
2000-04-05??? 0.792029
2000-04-06??? 0.901992
2000-04-07?? -1.138330
2000-04-08??? 0.264210
2000-04-09?? -1.102930
Freq: D, Length: 100, dtype: float64

ts.resample('M').mean()???????????? # 按月重采樣,按月計算平均值,結果按月聚合
2000-01-31?? -0.170285
2000-02-29??? 0.122144
2000-03-31??? 0.025351
2000-04-30?? -0.129685
Freq: M, dtype: float64

ts.resample('M', kind='period').mean()????????? # 聚合到周期,輸出如下:
2000-01?? -0.170285
2000-02??? 0.122144
2000-03??? 0.025351
2000-04?? -0.129685
Freq: M, dtype: float64
resample是?個靈活?效的?法,可?于處理?常?的時間序列。后面將通過?系列的示例說明其?法。
表11-5總結它的?些選項。

表11-5? resample?法的參數
參數??????????????????? 說明
freq??????????????????? 表示重采樣頻率的字符串或Dateoffset,例如'M'、'5min'或Second(15)
axis??????????????????? 重采樣的軸,默認為 axis=0
fill_method??????? 升采樣如何插值,比如'ffill'或'bfill'。默認不插值
closed??????????????? 在降采樣中,各時間段的哪一端是閉合(即包含)的,right或left。默認是right
label?????????????????? 在降采樣中,如何設置聚合值得標簽,right或left(面元的右邊界或左邊界)。
?????????????????????????? 例如,9:30到9:35之間的這5分鐘會被標記為9:30或9:35。默認為right
loffset???????????????? 面元標簽的時間校正值,比如'-1s'/Second(-1)用于將聚合標簽調早1秒
limit??????????????????? 在前向或后向填充時,允許填充的最大時間數
kind??????????????????? 聚合到周期('period')或時間戳('timestamp'),默認聚合到時間序列的索引類型
convention???????? 當對周期進行重采樣,將低頻周期轉換為高頻的慣用法('start'或'end');默認是'end'

1、降采樣
將數據聚合到規律的低頻率是?件?常普通的時間序列處理任務。待聚合的數據不必擁有固定的頻率,期望的頻率會?動定義聚合的?元邊界,這些?元?于將時間序列拆分為多個?段。例如,要轉換到?度頻率('M'或'BM'),數據需要被劃分到多個單?時間段中。各時間段都是半開放的。?個數據點只能屬于?個時間段,所有時間段的并集必須能組成整個時間幀。在?resample對數據進?降采樣時,需要考慮兩點:
???????????? 各區間哪邊是閉合的。
???????????? 如何標記各個聚合?元,?區間的開頭還是末尾。
為了說明,我們來看?些“1分鐘”數據:
rng = pd.date_range('2000-1-1', periods=12, freq='T')
ts = pd.Series(np.arange(12), index=rng)
ts????????????????????? # 輸出如下:
2000-01-01 00:00:00???? 0
2000-01-01 00:01:00???? 1
2000-01-01 00:02:00???? 2
2000-01-01 00:03:00???? 3
2000-01-01 00:04:00???? 4
2000-01-01 00:05:00???? 5
2000-01-01 00:06:00???? 6
2000-01-01 00:07:00???? 7
2000-01-01 00:08:00???? 8
2000-01-01 00:09:00???? 9
2000-01-01 00:10:00??? 10
2000-01-01 00:11:00??? 11
Freq: T, dtype: int32
假設你想要通過求和的?式將這些數據聚合到“5分鐘”塊中:
ts.resample('5min', closed='right').sum()?????? # 輸出如下:
1999-12-31 23:55:00???? 0
2000-01-01 00:00:00??? 15
2000-01-01 00:05:00??? 40
2000-01-01 00:10:00??? 11
Freq: 5T, dtype: int32

傳?的頻率將會以“5分鐘”的增量定義?元邊界。默認情況下,?元的右邊界是包含的,因此00:00到00:05的區間中是包含00:05的。傳?closed='left'會讓區間以左邊界閉合:
ts.resample('5min', closed='left').sum()??????? # 輸出如下:
2000-01-01 00:00:00??? 10
2000-01-01 00:05:00??? 35
2000-01-01 00:10:00??? 21
Freq: 5T, dtype: int32
如你所?,最終的時間序列是以各?元左邊界的時間戳進?標記的。傳?label='right'即可??元的右邊界對其進?標記:
ts.resample('5min', closed='left', label='right').sum()???? # 輸出如下:右邊界進行標記,但數據不包含右邊界
2000-01-01 00:05:00??? 10
2000-01-01 00:10:00??? 35
2000-01-01 00:15:00??? 21
Freq: 5T, dtype: int32

圖11-3說明了“1分鐘”數據被轉換為“5分鐘”數據的處理過程。


???????????????????????????? 圖11-3? 各種closed、label約定的“5分鐘”重采樣演示

最后,你可能希望對結果索引做?些位移,?如從右邊界減去?秒以便更容易明?該時間戳到底表示的是哪個區間。只需通過loffset設置?個字符串或?期偏移量即可實現這個?的:
ts.resample('5min', closed='left', label='right', loffset='-1s').sum()
2000-01-01 00:04:59??? 10
2000-01-01 00:09:59??? 35
2000-01-01 00:14:59??? 21
Freq: 5T, dtype: int32
此外,也可以通過調?結果對象的shift?法來實現該?的,這樣就不需要設置loffset了。

2、OHLC重采樣
?融領域中有?種?所不在的時間序列聚合?式,即計算各?元的四個值:第?個值(open,開盤)、最后?個
值(close,收盤)、最?值(high,最?)以及最?值(low,最低)。傳?how='ohlc'即可得到?個含有這四
種聚合值的DataFrame。整個過程很?效,只需?次掃描即可計算出結果:
ts.resample('5min').ohlc()????????????????????? # 輸出如下:
????????????????????????????????? open? high? low? close
2000-01-01 00:00:00????? 0?????? 4????? 0??????? 4
2000-01-01 00:05:00????? 5?????? 9????? 5??????? 9
2000-01-01 00:10:00??? 10???? 11??? 10????? 11

3、升采樣和插值
在將數據從低頻率轉換到?頻率時,就不需要聚合了。來看?個帶有?些周型數據(weekly data)的DataFrame:
frame = pd.DataFrame(np.random.randn(2, 4),
?????????????????????????????????????? index=pd.date_range('1/1/2000', periods=2, freq='W-WED'),
?????????????????????????????????????? columns=['Colorado', 'Texas', 'New York', 'Ohio'])
frame?????????????????? # 輸出如下:
????????????????????? Colorado?????? Texas? New York???????? Ohio
2000-01-05? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-12 -2.558629 -1.383027? 0.218594 -1.543188
當你對這個數據進?聚合,每組只有?個值,這樣就會引?缺失值。我們使?asfreq?法轉換成?頻,不經過聚合:
df_daily = frame.resample('D').asfreq()???????? # 會引入缺失值
df_daily??????????????? # 輸出如下:
????????????????????? Colorado?????? Texas? New York???????? Ohio
2000-01-05? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-06???????? NaN????????? NaN????????? NaN???????? NaN
2000-01-07???????? NaN????????? NaN????????? NaN???????? NaN
2000-01-08???????? NaN????????? NaN????????? NaN???????? NaN
2000-01-09???????? NaN????????? NaN????????? NaN???????? NaN
2000-01-10???????? NaN????????? NaN????????? NaN???????? NaN
2000-01-11???????? NaN????????? NaN????????? NaN???????? NaN
2000-01-12 -2.558629 -1.383027? 0.218594 -1.543188

假設你想要?前?的周型值填充“?星期三”。resampling的填充和插值?式跟fillna和reindex的?樣:
frame.resample('D').ffill()???????????????????? # 輸出如下:按天重采樣填充
????????????????????? Colorado?????? Texas? New York???????? Ohio
2000-01-05? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-06? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-07? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-08? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-09? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-10? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-11? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-12 -2.558629 -1.383027? 0.218594 -1.543188

同樣,這?也可以只填充指定的時期數(?的是限制前?的觀測值的持續使?距離):
frame.resample('D').ffill(limit=2)????????????? # 輸出如下:
????????????????????? Colorado?????? Texas? New York???????? Ohio
2000-01-05? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-06? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-07? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-08???????? NaN????????? NaN????????? NaN????????? NaN
2000-01-09???????? NaN????????? NaN????????? NaN????????? NaN
2000-01-10???????? NaN????????? NaN????????? NaN????????? NaN
2000-01-11???????? NaN????????? NaN????????? NaN????????? NaN
2000-01-12 -2.558629 -1.383027? 0.218594 -1.543188

注意,新的?期索引完全沒必要跟舊的重疊:
frame.resample('W-THU').ffill()
????????????????????? Colorado?????? Texas? New York???????? Ohio
2000-01-06? 1.454027 -0.827189 -1.434377 -0.714617
2000-01-13 -2.558629 -1.383027? 0.218594 -1.543188

4、通過時期進?重采樣
對那些使?時期索引的數據進?重采樣與時間戳很像:
frame = pd.DataFrame(np.random.randn(24, 4),
?????????????????????????????????????? index=pd.period_range('1-2000', '12-2001', freq='M'),
?????????????????????????????????????? columns=['Colorado', 'Texas', 'New York', 'Ohio'])
frame[:5]?????????????? # 前5行輸出如下:([-5:]取最后5行),也可用head()和tail()方法
???????????????? Colorado??????? Texas? New York??????? Ohio
2000-01 -0.122366 -1.482307 -1.511748 -1.001796
2000-02 -0.309046 -0.433579? 0.641963 -0.845334
2000-03? 1.467931? 1.524688 -1.107858? 1.721680
2000-04 -0.007002? 1.601335? 0.366802? 1.904509
2000-05 -1.687389 -1.237108 -0.567321 -0.918862
每年的最后一個月重采樣求平均值
annual_frame = frame.resample('A-DEC').mean()
annual_frame??????????????????????? # 輸出如下:
?????????? Colorado?????? Texas? New York??????? Ohio
2000? 0.293250 -0.001142? -0.25785? 0.007990
2001 -0.266541 -0.091771?? 0.56443 -0.783206

升采樣要稍微麻煩?些,因為你必須決定在新頻率中各區間的哪端?于放置原來的值,就像asfreq?法那樣。
convention參數默認為'start',可設置為'end':
# Q-DEC: Quarterly, year ending in December,按季度采樣,每年的最后一個月為邊界
annual_frame.resample('Q-DEC').ffill()????????? # convention參數默認為'start',升采樣
????????????? Colorado?????? Texas? New York??????? Ohio
2000Q1? 0.293250 -0.001142? -0.25785? 0.007990
2000Q2? 0.293250 -0.001142? -0.25785? 0.007990
2000Q3? 0.293250 -0.001142? -0.25785? 0.007990
2000Q4? 0.293250 -0.001142? -0.25785? 0.007990
2001Q1 -0.266541 -0.091771?? 0.56443 -0.783206
2001Q2 -0.266541 -0.091771?? 0.56443 -0.783206
2001Q3 -0.266541 -0.091771?? 0.56443 -0.783206
2001Q4 -0.266541 -0.091771?? 0.56443 -0.783206
convention參數設置為'end'
annual_frame.resample('Q-DEC', convention='end').ffill()
??????????????? Colorado?????? Texas? New York??????? Ohio
2000Q4? 0.293250 -0.001142? -0.25785? 0.007990
2001Q1? 0.293250 -0.001142? -0.25785? 0.007990
2001Q2? 0.293250 -0.001142? -0.25785? 0.007990
2001Q3? 0.293250 -0.001142? -0.25785? 0.007990
2001Q4 -0.266541 -0.091771?? 0.56443 -0.783206
由于時期指的是時間區間,所以升采樣和降采樣的規則就?較嚴格:
???????????? 在降采樣中,?標頻率必須是源頻率的?時期(subperiod)。
???????????? 在升采樣中,?標頻率必須是源頻率的父時期(superperiod)。

如果不滿?這些條件,就會引發異常。這主要影響的是按季、年、周計算的頻率。例如,由Q-MAR定義的時間區間只能升采樣為A-MAR、A-JUN、A-SEP、A-DEC等:
annual_frame.resample('Q-MAR').ffill()????????? # 輸出如下:
??????????????? Colorado?????? Texas? New York??????? Ohio
2000Q4? 0.293250 -0.001142? -0.25785? 0.007990
2001Q1? 0.293250 -0.001142? -0.25785? 0.007990
2001Q2? 0.293250 -0.001142? -0.25785? 0.007990
2001Q3? 0.293250 -0.001142? -0.25785? 0.007990
2001Q4 -0.266541 -0.091771?? 0.56443 -0.783206
2002Q1 -0.266541 -0.091771?? 0.56443 -0.783206
2002Q2 -0.266541 -0.091771?? 0.56443 -0.783206
2002Q3 -0.266541 -0.091771?? 0.56443 -0.783206

七、移動窗?函數
在移動窗?(可以帶有指數衰減權數)上計算的各種統計函數也是?類常?于時間序列的數組變換。這樣可以圓滑噪?數據或斷裂數據。我將它們稱為移動窗?函數(moving window function),其中還包括那些窗?不定?的函數(如指數加權移動平均)。跟其他統計函數?樣,移動窗?函數也會?動排除缺失值。

首先加載?些時間序列數據,將其重采樣為?作?頻率:
close_px_all = pd.read_csv('examples/stock_px_2.csv',
??????????????????????????????????????????? parse_dates=True, index_col=0)
close_px = close_px_all[['AAPL', 'MSFT', 'XOM']]??????????? # 取指定列的數據
close_px = close_px.resample('B').ffill()?????? # 根據每工作日重采樣

現在引?rolling運算符,它與resample和groupby很像。可以在TimeSeries或DataFrame以及?個window(表示期數,?圖11-4)上調?它:
close_px.AAPL.plot()
<matplotlib.axes._subplots.AxesSubplot at 0x1a6ac2ab668>
close_px.AAPL.rolling(250).mean().plot()??????? # 輸出圖形11-4
Out[150]: <matplotlib.axes._subplots.AxesSubplot at 0x1a6ac2ab668>


???????????????????????????????????????????? 圖11-4? 蘋果公司股價的250?均線

表達式rolling(250)與groupby很像,但不是對其進行分組,而是創建一個按照250天分組的滑動窗口對象。然后,就得到了蘋果公司股價的250天的移動窗口。

默認情況下,rolling函數需要窗口中所有的值為非NA值。可以修改該行為以解決缺失數據的問題。其實,在時間序列開始處尚不足窗口期的那些數據就是個特例(見圖11-5)
appl_std250 = close_px.AAPL.rolling(250, min_periods=10).std()
appl_std250[5:12]?????????????????? # 輸出如下:
2003-01-09?????????? NaN
2003-01-10?????????? NaN
2003-01-13?????????? NaN
2003-01-14?????????? NaN
2003-01-15??? 0.077496
2003-01-16??? 0.074760
2003-01-17??? 0.112368
Freq: B, Name: AAPL, dtype: float64
appl_std250.plot()????????????????? # 輸出圖形11-5


????????????????????????????????????????? 圖11-5? 蘋果公司250?每?回報標準差

要計算擴展窗口平均(expanding window mean),可以使用expanding而不是rolling。“擴展”意味著,
從時間序列的起始處開始窗口,增加窗口直到它超過所有的序列
。apple_std250時間序列的擴展窗口平均如
下所示:
expanding_mean = appl_std250.expanding().mean()

對DataFrame調?rolling_mean(以及與之類似的函數)會將轉換應?到所有的列上(?圖11-6):
close_px.rolling(60).mean().plot(logy=True)???? # 輸出圖形11-6


????????????????????????????????????????????? 圖11-6 各股價60?均線(對數Y軸)

rolling函數也可以接受一個指定固定大小時間補償字符串,而不是一組時期。這樣可以方便處理不規律的時間序
列。這些字符串也可以傳遞給resample。例如,我們可以計算20天的滾動均值,如下所示:
close_px.rolling('20D').mean()????????????????? # 輸出如下:
???????????????????????????? AAPL????????? MSFT????????? XOM
2003-01-02??? 7.400000? 21.110000? 29.220000
2003-01-03??? 7.425000? 21.125000? 29.230000
2003-01-06??? 7.433333? 21.256667? 29.473333
2003-01-07??? 7.432500? 21.425000? 29.342500
2003-01-08??? 7.402000? 21.402000? 29.240000
...??????????????????????????????? ...?????????????? ...???????????????? ...
2011-10-10? 389.351429? 25.602143? 72.527857
2011-10-11? 388.505000? 25.674286? 72.835000
2011-10-12? 388.531429? 25.810000? 73.400714
2011-10-13? 388.826429? 25.961429? 73.905000
2011-10-14? 391.038000? 26.048667? 74.185333

[2292 rows x 3 columns]

1、指數加權函數
另?種使?固定??窗?及相等權數觀測值的辦法是,定義?個衰減因?(decay factor)常量,以便使近期的觀測值擁有更?的權數。衰減因?的定義?式有很多,?較流?的是使?時間間隔(span),它可以使結果兼容于窗???等于時間間隔的簡單移動窗?(simple moving window)函數

由于指數加權統計會賦予近期的觀測值更?的權數,因此相對于等權統計,它能“適應”更快的變化。

除了rolling和expanding,pandas還有ewm運算符。下?這個例?對?了蘋果公司股價的30?移動平均和span=30的指數加權移動平均(如圖11-7所示):
appl_px = close_px.AAPL['2006':'2007']
ma30 = appl_px.rolling(30, min_periods=30).mean()?????????? # 30日移動平均
ewma30 = appl_px.ewm(span=30).mean()??????????? # 30日移動加權平均
ma30.plot(style='r--', label='Simple MA')
ewma30.plot(style='b-', label='EW MA')
plt.legend()??????????? # 輸出圖形11-7


????????????????????????????????????????? 圖11-7? 簡單移動平均與指數加權移動平均

2、?元移動窗?函數
有些統計運算(如相關系數和協方差)需要在兩個時間序列上執行。例如,金融分析師常常對某只股票對某個參考指數(如標準普爾500指數)的相關系數感興趣。要進行說明,我們先計算我們感興趣的時間序列的百分數變化
spx_px = close_px_all['SPX']
spx_rets = spx_px.pct_change()
returns = close_px.pct_change()

調?rolling之后,corr聚合函數開始計算與spx_rets滾動相關系數(結果?圖11-8):
corr = returns.AAPL.rolling(125, min_periods=100).corr(spx_rets)
corr.plot()???????????? # 輸出圖形11-8


???????????????????????????????? 圖11-8? AAPL 6個?的回報與標準普爾500指數的相關系數

假設你想要一次性計算多只股票與標準普爾500指數的相關系數。雖然編寫一個循環并新建一個DataFrame不是什么難事,但比較啰嗦。其實,只需傳入一個TimeSeries和一個DataFrame,rolling_corr就會自動計算TimeSeries(本例中就是spx_rets)與DataFrame各列的相關系數。結果如圖11-9所示:
corr = returns.rolling(125, min_periods=100).corr(spx_rets)
corr.plot()???????????? # 輸出圖形11-9


??????????????????????????????????? 圖11-9? 3只股票6個?的回報與標準普爾500指數的相關系數

3、?戶定義的移動窗?函數
rolling_apply函數使你能夠在移動窗?上應???設計的數組函數。唯?要求的就是:該函數要能從數組的各個?段中產?單個值(即約簡)。?如說,當我們?rolling(...).quantile(q)計算樣本分位數時,可能對樣本中特定值的百分等級感興趣。scipy.stats.percentileofscore函數就能達到這個?的(結果?圖11-10):
from scipy.stats import percentileofscore
score_at_2percent = lambda x: percentileofscore(x, 0.02)
result = returns.AAPL.rolling(250).apply(score_at_2percent)
result.plot()?????????? # 輸出圖形11-10


???????????????????????????????? 圖11-10? AAPL 2%回報率的百分等級(?年窗?期)
如果沒安裝SciPy,可以使?conda或pip安裝。

八、總結
與之前接觸到的數據相?,時間序列數據要求不同類型的分析和數據轉換?具。

轉載于:https://www.cnblogs.com/Micro0623/p/10190574.html

總結

以上是生活随笔為你收集整理的第十一篇 时间序列的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

国产内射老熟女aaaa | 中文字幕无线码 | 激情五月综合色婷婷一区二区 | 99国产欧美久久久精品 | 又粗又大又硬又长又爽 | 国产成人无码a区在线观看视频app | 清纯唯美经典一区二区 | 综合激情五月综合激情五月激情1 | 色综合久久网 | 欧洲熟妇精品视频 | 成人亚洲精品久久久久软件 | 国产精品久久久一区二区三区 | 欧洲极品少妇 | 九月婷婷人人澡人人添人人爽 | 帮老师解开蕾丝奶罩吸乳网站 | 婷婷五月综合激情中文字幕 | 少妇无码吹潮 | 欧洲熟妇精品视频 | 少妇被粗大的猛进出69影院 | 免费观看的无遮挡av | 丰满少妇熟乱xxxxx视频 | 少妇被黑人到高潮喷出白浆 | 极品嫩模高潮叫床 | 婷婷丁香五月天综合东京热 | 久久 国产 尿 小便 嘘嘘 | 亚洲自偷精品视频自拍 | 熟妇人妻无乱码中文字幕 | 亚洲七七久久桃花影院 | 秋霞特色aa大片 | 久久成人a毛片免费观看网站 | 中国女人内谢69xxxx | 婷婷五月综合激情中文字幕 | 日日干夜夜干 | 麻豆果冻传媒2021精品传媒一区下载 | 国产女主播喷水视频在线观看 | 欧美性猛交xxxx富婆 | 亚洲呦女专区 | 国内揄拍国内精品人妻 | 国产精品香蕉在线观看 | 国内精品人妻无码久久久影院蜜桃 | 成人aaa片一区国产精品 | 欧美国产日产一区二区 | 色综合久久中文娱乐网 | 在线成人www免费观看视频 | 国产成人精品久久亚洲高清不卡 | 一本久道久久综合狠狠爱 | 亚洲va欧美va天堂v国产综合 | 久久久久久国产精品无码下载 | 日日碰狠狠丁香久燥 | 人妻插b视频一区二区三区 | 亚洲精品国产第一综合99久久 | 国产亚洲精品久久久久久大师 | 中文精品久久久久人妻不卡 | 99久久亚洲精品无码毛片 | 99久久精品午夜一区二区 | 日本丰满熟妇videos | 欧美国产亚洲日韩在线二区 | 亚洲熟妇色xxxxx欧美老妇 | 亚洲性无码av中文字幕 | ass日本丰满熟妇pics | 奇米影视7777久久精品 | 亚洲男女内射在线播放 | 色诱久久久久综合网ywww | 国产免费久久精品国产传媒 | 中文字幕+乱码+中文字幕一区 | 久久综合久久自在自线精品自 | 伊人久久婷婷五月综合97色 | 久久久精品国产sm最大网站 | 色欲久久久天天天综合网精品 | 色一情一乱一伦一区二区三欧美 | www成人国产高清内射 | 人人妻在人人 | 亚洲熟悉妇女xxx妇女av | 中文字幕无码乱人伦 | 亚洲综合另类小说色区 | 日本护士毛茸茸高潮 | 色婷婷综合激情综在线播放 | 亚洲精品一区二区三区四区五区 | 丝袜 中出 制服 人妻 美腿 | 亚洲国产成人av在线观看 | 性欧美熟妇videofreesex | 婷婷丁香六月激情综合啪 | 成熟人妻av无码专区 | 久久精品国产亚洲精品 | 无码午夜成人1000部免费视频 | 荫蒂被男人添的好舒服爽免费视频 | 88国产精品欧美一区二区三区 | 麻豆国产人妻欲求不满 | 欧美精品免费观看二区 | 精品欧洲av无码一区二区三区 | 粉嫩少妇内射浓精videos | 久久国产精品萌白酱免费 | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲欧洲中文日韩av乱码 | 人妻无码αv中文字幕久久琪琪布 | 色欲综合久久中文字幕网 | 亚洲人成人无码网www国产 | 午夜成人1000部免费视频 | 亚洲熟悉妇女xxx妇女av | 亚洲精品欧美二区三区中文字幕 | 午夜无码人妻av大片色欲 | 永久免费精品精品永久-夜色 | 男女猛烈xx00免费视频试看 | 丰满少妇高潮惨叫视频 | 日韩亚洲欧美中文高清在线 | 欧美性生交活xxxxxdddd | 好男人社区资源 | 永久黄网站色视频免费直播 | 日韩无套无码精品 | 丰满肥臀大屁股熟妇激情视频 | 一个人看的视频www在线 | 久久精品中文字幕大胸 | 免费无码的av片在线观看 | 呦交小u女精品视频 | 成人欧美一区二区三区黑人 | 亚洲成av人综合在线观看 | 亚洲一区二区三区偷拍女厕 | 男人扒开女人内裤强吻桶进去 | 日本高清一区免费中文视频 | 在线成人www免费观看视频 | 粉嫩少妇内射浓精videos | 少妇的肉体aa片免费 | 男女猛烈xx00免费视频试看 | 免费中文字幕日韩欧美 | 欧美第一黄网免费网站 | 国产午夜无码视频在线观看 | 狠狠噜狠狠狠狠丁香五月 | 小泽玛莉亚一区二区视频在线 | 欧美日韩一区二区三区自拍 | www国产亚洲精品久久久日本 | 麻豆国产人妻欲求不满 | 精品欧洲av无码一区二区三区 | 中文字幕 人妻熟女 | 小sao货水好多真紧h无码视频 | 国产xxx69麻豆国语对白 | 亚洲国产高清在线观看视频 | 亚洲精品一区三区三区在线观看 | 99精品无人区乱码1区2区3区 | 特黄特色大片免费播放器图片 | 少妇被黑人到高潮喷出白浆 | 窝窝午夜理论片影院 | 蜜臀aⅴ国产精品久久久国产老师 | 国产免费无码一区二区视频 | 99久久亚洲精品无码毛片 | 色一情一乱一伦 | 兔费看少妇性l交大片免费 | 少妇人妻大乳在线视频 | 精品偷自拍另类在线观看 | 国产成人无码a区在线观看视频app | 国产精品人妻一区二区三区四 | 国产精品高潮呻吟av久久4虎 | 男人的天堂2018无码 | 国产 精品 自在自线 | 国产激情无码一区二区 | 性生交片免费无码看人 | 免费男性肉肉影院 | 人人超人人超碰超国产 | 又大又黄又粗又爽的免费视频 | 国产午夜亚洲精品不卡 | 色狠狠av一区二区三区 | 国产精品久久久av久久久 | 国产熟妇高潮叫床视频播放 | 国产xxx69麻豆国语对白 | 一本久道高清无码视频 | 野外少妇愉情中文字幕 | 国产精品无码一区二区桃花视频 | 老子影院午夜伦不卡 | 中文字幕中文有码在线 | 久久人人爽人人爽人人片ⅴ | 无人区乱码一区二区三区 | 欧美乱妇无乱码大黄a片 | 日本精品高清一区二区 | 窝窝午夜理论片影院 | 日本成熟视频免费视频 | 亚洲国产精品无码一区二区三区 | 无套内射视频囯产 | 男人的天堂2018无码 | 精品国产一区av天美传媒 | 人妻体内射精一区二区三四 | 国产精品久久国产精品99 | 狂野欧美性猛xxxx乱大交 | 久久久久99精品成人片 | 午夜福利不卡在线视频 | 色欲av亚洲一区无码少妇 | av香港经典三级级 在线 | av香港经典三级级 在线 | 国产激情无码一区二区app | 亚洲色欲久久久综合网东京热 | 麻豆国产97在线 | 欧洲 | 水蜜桃色314在线观看 | 亚洲人亚洲人成电影网站色 | 无遮挡国产高潮视频免费观看 | 男女猛烈xx00免费视频试看 | 亲嘴扒胸摸屁股激烈网站 | 国产 浪潮av性色四虎 | v一区无码内射国产 | 亚洲伊人久久精品影院 | 久久久久免费精品国产 | 国产真人无遮挡作爱免费视频 | 少妇被黑人到高潮喷出白浆 | 少妇无码av无码专区在线观看 | 婷婷五月综合激情中文字幕 | 国产色在线 | 国产 | 日韩欧美中文字幕在线三区 | 久久久久av无码免费网 | 老子影院午夜伦不卡 | 天天综合网天天综合色 | 久久亚洲a片com人成 | 日韩人妻少妇一区二区三区 | 婷婷色婷婷开心五月四房播播 | 日本在线高清不卡免费播放 | 国产激情无码一区二区app | 日本一卡二卡不卡视频查询 | 亚洲成av人综合在线观看 | 大地资源网第二页免费观看 | 亚洲 日韩 欧美 成人 在线观看 | 一本精品99久久精品77 | 欧洲美熟女乱又伦 | 久久午夜夜伦鲁鲁片无码免费 | 性做久久久久久久久 | 国产成人精品久久亚洲高清不卡 | 国产精品多人p群无码 | 久久亚洲国产成人精品性色 | 人人超人人超碰超国产 | 国产成人无码av片在线观看不卡 | 国产精品沙发午睡系列 | 欧美日韩人成综合在线播放 | 一本色道久久综合亚洲精品不卡 | 国产免费观看黄av片 | 蜜桃无码一区二区三区 | 国产精品第一国产精品 | 鲁大师影院在线观看 | www一区二区www免费 | 国产精品久久久久无码av色戒 | 中文字幕无码热在线视频 | 午夜福利试看120秒体验区 | 中文字幕精品av一区二区五区 | 无码国产乱人伦偷精品视频 | 日日躁夜夜躁狠狠躁 | 亚洲欧美日韩综合久久久 | 377p欧洲日本亚洲大胆 | 一本精品99久久精品77 | 日本一卡二卡不卡视频查询 | 久久久久久亚洲精品a片成人 | 国产午夜无码视频在线观看 | a在线亚洲男人的天堂 | 久久精品国产一区二区三区 | 清纯唯美经典一区二区 | 亚洲国产日韩a在线播放 | 欧美人与禽猛交狂配 | 天堂在线观看www | 亚洲の无码国产の无码影院 | 美女黄网站人色视频免费国产 | 精品无码国产自产拍在线观看蜜 | 成熟人妻av无码专区 | 久久久久久av无码免费看大片 | 精品国偷自产在线视频 | 丰腴饱满的极品熟妇 | 国产亚洲精品久久久久久久久动漫 | 99er热精品视频 | 亚洲国产成人av在线观看 | 国产亚洲美女精品久久久2020 | 欧美xxxxx精品 | 人人妻人人澡人人爽欧美精品 | 亚洲精品成人福利网站 | 日韩精品无码免费一区二区三区 | 国产一区二区三区四区五区加勒比 | 亚洲中文字幕在线无码一区二区 | 天天躁日日躁狠狠躁免费麻豆 | 国产综合色产在线精品 | 亚洲日韩乱码中文无码蜜桃臀网站 | 欧美亚洲国产一区二区三区 | 一本久道高清无码视频 | 国产一区二区三区四区五区加勒比 | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲国产欧美在线成人 | 正在播放老肥熟妇露脸 | 国内丰满熟女出轨videos | 中文字幕乱码人妻无码久久 | 亚洲熟悉妇女xxx妇女av | 在线播放免费人成毛片乱码 | 国产精品二区一区二区aⅴ污介绍 | 国产成人综合色在线观看网站 | 久久久久久久人妻无码中文字幕爆 | 国产精品第一区揄拍无码 | 国产在线精品一区二区高清不卡 | 无码免费一区二区三区 | 97夜夜澡人人爽人人喊中国片 | 日本xxxx色视频在线观看免费 | 久久久久免费看成人影片 | 中国女人内谢69xxxx | 亚洲一区二区三区无码久久 | 成在人线av无码免观看麻豆 | 99久久精品午夜一区二区 | 免费乱码人妻系列无码专区 | 97久久超碰中文字幕 | 亚洲国产综合无码一区 | 成人欧美一区二区三区黑人免费 | 久久久久av无码免费网 | 国产成人无码专区 | 国产成人综合在线女婷五月99播放 | 丰满少妇熟乱xxxxx视频 | 亚洲区小说区激情区图片区 | 色综合视频一区二区三区 | 久久精品人妻少妇一区二区三区 | 亚洲日韩av一区二区三区四区 | 99精品无人区乱码1区2区3区 | 久久久久国色av免费观看性色 | 国产做国产爱免费视频 | 国产综合色产在线精品 | 美女毛片一区二区三区四区 | 亚洲综合另类小说色区 | 亚洲欧洲中文日韩av乱码 | 性欧美videos高清精品 | 一区二区三区高清视频一 | 麻花豆传媒剧国产免费mv在线 | 国产精品久久精品三级 | 亚洲欧洲无卡二区视頻 | 亚洲欧美日韩国产精品一区二区 | 国产艳妇av在线观看果冻传媒 | 一本久久伊人热热精品中文字幕 | 国产精品va在线观看无码 | 亚洲精品国产精品乱码视色 | 国产电影无码午夜在线播放 | 任你躁国产自任一区二区三区 | 免费国产成人高清在线观看网站 | 日本一区二区三区免费播放 | 久久人人爽人人爽人人片ⅴ | 在线观看国产一区二区三区 | 国产乱子伦视频在线播放 | 欧美日韩视频无码一区二区三 | 欧美真人作爱免费视频 | 国内少妇偷人精品视频免费 | 国产激情综合五月久久 | 亚洲一区二区三区偷拍女厕 | 久久熟妇人妻午夜寂寞影院 | 日韩人妻无码中文字幕视频 | 人妻无码久久精品人妻 | 亚洲人成人无码网www国产 | 少妇人妻偷人精品无码视频 | 亚洲人交乣女bbw | 少妇性俱乐部纵欲狂欢电影 | 乱人伦人妻中文字幕无码 | 国产性生大片免费观看性 | 欧美精品免费观看二区 | 无码中文字幕色专区 | 伊在人天堂亚洲香蕉精品区 | 精品无码一区二区三区爱欲 | 欧美成人午夜精品久久久 | 99久久精品无码一区二区毛片 | 亚洲熟悉妇女xxx妇女av | 日本一卡2卡3卡四卡精品网站 | 久久久久成人精品免费播放动漫 | 鲁大师影院在线观看 | 国产网红无码精品视频 | 国产成人无码午夜视频在线观看 | 日韩精品无码免费一区二区三区 | 性开放的女人aaa片 | 在线观看国产午夜福利片 | 无码国模国产在线观看 | 无码一区二区三区在线观看 | 成人女人看片免费视频放人 | 久久亚洲国产成人精品性色 | 强开小婷嫩苞又嫩又紧视频 | 亚洲日韩av一区二区三区四区 | 欧美日韩一区二区免费视频 | 在教室伦流澡到高潮hnp视频 | 精品国产精品久久一区免费式 | 亚洲天堂2017无码中文 | 欧美变态另类xxxx | 麻豆国产97在线 | 欧洲 | 国产免费久久精品国产传媒 | 国产婷婷色一区二区三区在线 | 精品欧洲av无码一区二区三区 | 影音先锋中文字幕无码 | 四虎永久在线精品免费网址 | 鲁一鲁av2019在线 | 日韩欧美成人免费观看 | 国产香蕉尹人综合在线观看 | 国产欧美精品一区二区三区 | 国产suv精品一区二区五 | 欧洲vodafone精品性 | 国产精品久久久av久久久 | 欧美乱妇无乱码大黄a片 | 午夜时刻免费入口 | 亚洲精品一区二区三区婷婷月 | 国产熟妇另类久久久久 | 水蜜桃av无码 | 亚洲欧美日韩综合久久久 | 亚洲狠狠婷婷综合久久 | 丰满肥臀大屁股熟妇激情视频 | 激情爆乳一区二区三区 | 亚洲国产精品成人久久蜜臀 | 国产午夜视频在线观看 | 国产亚洲人成在线播放 | 国产人妻人伦精品 | 少妇高潮一区二区三区99 | 国产高清av在线播放 | 亚洲最大成人网站 | 沈阳熟女露脸对白视频 | 无码免费一区二区三区 | 久久精品中文闷骚内射 | 精品厕所偷拍各类美女tp嘘嘘 | 午夜福利电影 | 国产精品国产自线拍免费软件 | 中文无码成人免费视频在线观看 | 人人爽人人爽人人片av亚洲 | 亚洲色www成人永久网址 | 亚洲一区二区三区在线观看网站 | 亚洲日韩一区二区三区 | 成人无码精品1区2区3区免费看 | 中文字幕人妻无码一夲道 | 午夜熟女插插xx免费视频 | 亚洲欧美精品aaaaaa片 | 国产内射老熟女aaaa | 亚洲欧美日韩成人高清在线一区 | 欧美日本日韩 | 亚洲综合无码久久精品综合 | 亚洲人成网站色7799 | 小sao货水好多真紧h无码视频 | 精品成在人线av无码免费看 | 99精品无人区乱码1区2区3区 | 国产午夜精品一区二区三区嫩草 | 国产精品二区一区二区aⅴ污介绍 | 小泽玛莉亚一区二区视频在线 | 一个人免费观看的www视频 | 亚洲国精产品一二二线 | 99久久婷婷国产综合精品青草免费 | 欧洲熟妇色 欧美 | 国产乱子伦视频在线播放 | 中文字幕av无码一区二区三区电影 | 国产在线aaa片一区二区99 | 亚洲精品中文字幕乱码 | 精品国产成人一区二区三区 | 国产色xx群视频射精 | 国产高潮视频在线观看 | 欧美性黑人极品hd | 一本色道久久综合狠狠躁 | 精品久久综合1区2区3区激情 | 久久国产劲爆∧v内射 | 好屌草这里只有精品 | 天天摸天天透天天添 | 亚洲人成人无码网www国产 | 欧美日韩人成综合在线播放 | 国产香蕉97碰碰久久人人 | 欧美激情综合亚洲一二区 | 日韩精品乱码av一区二区 | 乱人伦人妻中文字幕无码久久网 | 女高中生第一次破苞av | 久久亚洲国产成人精品性色 | 欧美日韩一区二区三区自拍 | 国产精华av午夜在线观看 | 久久精品国产一区二区三区肥胖 | av香港经典三级级 在线 | 久久 国产 尿 小便 嘘嘘 | 日韩无码专区 | 国产两女互慰高潮视频在线观看 | 国产麻豆精品精东影业av网站 | 精品少妇爆乳无码av无码专区 | 好爽又高潮了毛片免费下载 | 午夜精品久久久久久久久 | 国产美女精品一区二区三区 | 亚洲熟妇色xxxxx亚洲 | 日日碰狠狠躁久久躁蜜桃 | 男女猛烈xx00免费视频试看 | 国产性生大片免费观看性 | 小sao货水好多真紧h无码视频 | 窝窝午夜理论片影院 | 福利一区二区三区视频在线观看 | 在线播放免费人成毛片乱码 | 无码吃奶揉捏奶头高潮视频 | 少妇的肉体aa片免费 | 国产亚洲人成在线播放 | 图片小说视频一区二区 | 欧美国产日产一区二区 | 色狠狠av一区二区三区 | 日韩人妻无码一区二区三区久久99 | 欧美zoozzooz性欧美 | 成人女人看片免费视频放人 | 无码国内精品人妻少妇 | 鲁一鲁av2019在线 | 欧美亚洲日韩国产人成在线播放 | 午夜精品一区二区三区的区别 | 亚洲精品午夜国产va久久成人 | 国产美女精品一区二区三区 | 亚洲一区二区三区香蕉 | 欧美亚洲国产一区二区三区 | 色诱久久久久综合网ywww | 麻花豆传媒剧国产免费mv在线 | 亚欧洲精品在线视频免费观看 | 99久久久无码国产aaa精品 | 国内老熟妇对白xxxxhd | 日日摸夜夜摸狠狠摸婷婷 | 久久久久成人片免费观看蜜芽 | 人人澡人摸人人添 | 性欧美大战久久久久久久 | 免费观看的无遮挡av | 国产区女主播在线观看 | 欧美亚洲日韩国产人成在线播放 | 国产成人一区二区三区在线观看 | 亚洲熟妇色xxxxx欧美老妇 | 免费看少妇作爱视频 | 欧美成人午夜精品久久久 | 中文字幕av伊人av无码av | 帮老师解开蕾丝奶罩吸乳网站 | 在线a亚洲视频播放在线观看 | 又色又爽又黄的美女裸体网站 | 成熟妇人a片免费看网站 | 久热国产vs视频在线观看 | 人人妻人人澡人人爽欧美精品 | 亚洲精品国产第一综合99久久 | 亚洲狠狠色丁香婷婷综合 | 婷婷丁香五月天综合东京热 | 午夜性刺激在线视频免费 | 日日橹狠狠爱欧美视频 | 色情久久久av熟女人妻网站 | 成人免费无码大片a毛片 | 牛和人交xxxx欧美 | 午夜肉伦伦影院 | 亚洲欧洲日本无在线码 | 波多野结衣一区二区三区av免费 | 精品国产福利一区二区 | 人人妻人人藻人人爽欧美一区 | 亚洲区欧美区综合区自拍区 | 一区二区传媒有限公司 | 一本无码人妻在中文字幕免费 | 人妻aⅴ无码一区二区三区 | 亚洲国产精品久久人人爱 | 麻豆国产人妻欲求不满谁演的 | 久久精品国产一区二区三区肥胖 | 无套内射视频囯产 | 偷窥日本少妇撒尿chinese | 扒开双腿疯狂进出爽爽爽视频 | 久久久久久久久蜜桃 | 免费观看的无遮挡av | 少妇高潮一区二区三区99 | 国产精品毛片一区二区 | 中文字幕人妻无码一区二区三区 | 成年美女黄网站色大免费视频 | 四虎永久在线精品免费网址 | 亚洲国产午夜精品理论片 | 丝袜美腿亚洲一区二区 | 99精品国产综合久久久久五月天 | 亚洲精品成a人在线观看 | 日本爽爽爽爽爽爽在线观看免 | 久青草影院在线观看国产 | 人妻少妇精品无码专区二区 | 亚洲精品久久久久久一区二区 | 久久久婷婷五月亚洲97号色 | 久久亚洲中文字幕无码 | 高潮喷水的毛片 | 99精品视频在线观看免费 | 天堂亚洲免费视频 | 1000部啪啪未满十八勿入下载 | 国产国产精品人在线视 | 久久综合九色综合97网 | 国产精品亚洲综合色区韩国 | 亚洲男人av香蕉爽爽爽爽 | 无码帝国www无码专区色综合 | 一区二区三区乱码在线 | 欧洲 | 大乳丰满人妻中文字幕日本 | 又紧又大又爽精品一区二区 | 国产香蕉尹人综合在线观看 | 又大又硬又爽免费视频 | 国产精品亚洲一区二区三区喷水 | 亚洲成av人综合在线观看 | 久久久久久久女国产乱让韩 | 久久五月精品中文字幕 | 中文字幕无码免费久久99 | 成人毛片一区二区 | 欧美精品在线观看 | 免费国产成人高清在线观看网站 | 牛和人交xxxx欧美 | 77777熟女视频在线观看 а天堂中文在线官网 | 99精品国产综合久久久久五月天 | 亚洲精品中文字幕久久久久 | 狠狠色欧美亚洲狠狠色www | 成人免费视频在线观看 | aⅴ在线视频男人的天堂 | 欧美高清在线精品一区 | 久久久久国色av免费观看性色 | 国产莉萝无码av在线播放 | 青春草在线视频免费观看 | 欧美熟妇另类久久久久久多毛 | 亚洲啪av永久无码精品放毛片 | 成人无码精品一区二区三区 | 久久无码中文字幕免费影院蜜桃 | 在教室伦流澡到高潮hnp视频 | 国产性生大片免费观看性 | 漂亮人妻洗澡被公强 日日躁 | 国产欧美熟妇另类久久久 | 欧美怡红院免费全部视频 | 麻豆精产国品 | 日韩成人一区二区三区在线观看 | 欧美老妇交乱视频在线观看 | 日日摸夜夜摸狠狠摸婷婷 | 丰满少妇人妻久久久久久 | 中文字幕乱码人妻二区三区 | 性生交片免费无码看人 | 一本大道伊人av久久综合 | 色情久久久av熟女人妻网站 | 国色天香社区在线视频 | 成人欧美一区二区三区黑人 | 久久久久久久人妻无码中文字幕爆 | 在线欧美精品一区二区三区 | 国产亚洲精品久久久久久 | 少妇性l交大片欧洲热妇乱xxx | 激情人妻另类人妻伦 | 国内综合精品午夜久久资源 | 精品无码成人片一区二区98 | 丁香啪啪综合成人亚洲 | 亚洲の无码国产の无码影院 | 伊人久久大香线焦av综合影院 | av人摸人人人澡人人超碰下载 | 亚洲中文字幕在线观看 | 99久久精品国产一区二区蜜芽 | 99久久99久久免费精品蜜桃 | 欧美 丝袜 自拍 制服 另类 | 亚洲精品国偷拍自产在线麻豆 | 欧美刺激性大交 | 两性色午夜视频免费播放 | 精品乱码久久久久久久 | 亚洲男人av香蕉爽爽爽爽 | 捆绑白丝粉色jk震动捧喷白浆 | 九一九色国产 | 老司机亚洲精品影院 | 98国产精品综合一区二区三区 | 永久免费观看国产裸体美女 | 欧美freesex黑人又粗又大 | 任你躁在线精品免费 | 亚洲人亚洲人成电影网站色 | 欧美freesex黑人又粗又大 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 日日天干夜夜狠狠爱 | 欧美三级a做爰在线观看 | 性啪啪chinese东北女人 | 日本乱人伦片中文三区 | 国产做国产爱免费视频 | 免费观看黄网站 | 亚洲精品久久久久中文第一幕 | 国产亚洲精品久久久久久国模美 | 一个人免费观看的www视频 | 秋霞成人午夜鲁丝一区二区三区 | 中文精品久久久久人妻不卡 | 国产黄在线观看免费观看不卡 | 精品夜夜澡人妻无码av蜜桃 | 亚洲成熟女人毛毛耸耸多 | 国产熟妇另类久久久久 | 精品水蜜桃久久久久久久 | 久久亚洲日韩精品一区二区三区 | 在线成人www免费观看视频 | 亚洲精品一区二区三区在线观看 | 久久精品国产亚洲精品 | 精品少妇爆乳无码av无码专区 | 狠狠色噜噜狠狠狠7777奇米 | 伊人久久大香线蕉av一区二区 | 中文字幕中文有码在线 | 日韩精品a片一区二区三区妖精 | 日本一本二本三区免费 | 国产超碰人人爽人人做人人添 | 亚洲国产综合无码一区 | 亚洲日韩av一区二区三区四区 | 天天做天天爱天天爽综合网 | 夜先锋av资源网站 | 成人毛片一区二区 | 国产成人午夜福利在线播放 | 色情久久久av熟女人妻网站 | 亚洲а∨天堂久久精品2021 | 蜜桃av抽搐高潮一区二区 | 日韩人妻无码一区二区三区久久99 | 成人免费视频一区二区 | 十八禁视频网站在线观看 | 波多野结衣av在线观看 | 无码av最新清无码专区吞精 | 特级做a爰片毛片免费69 | 人妻中文无码久热丝袜 | 蜜臀av无码人妻精品 | 亚洲另类伦春色综合小说 | 内射后入在线观看一区 | 成年美女黄网站色大免费视频 | 99国产欧美久久久精品 | 人妻插b视频一区二区三区 | 在线精品国产一区二区三区 | 鲁鲁鲁爽爽爽在线视频观看 | 成人无码影片精品久久久 | 人人爽人人澡人人人妻 | 亚洲色www成人永久网址 | 西西人体www44rt大胆高清 | 国产精品美女久久久久av爽李琼 | 日本精品久久久久中文字幕 | a在线亚洲男人的天堂 | 日本乱人伦片中文三区 | 乱人伦人妻中文字幕无码 | 亚洲一区av无码专区在线观看 | 波多野结衣乳巨码无在线观看 | 亚洲一区二区三区含羞草 | 少妇被黑人到高潮喷出白浆 | 无遮挡国产高潮视频免费观看 | 精品无码一区二区三区的天堂 | 久久精品国产日本波多野结衣 | 亚拍精品一区二区三区探花 | 日本爽爽爽爽爽爽在线观看免 | 亚洲乱码国产乱码精品精 | 3d动漫精品啪啪一区二区中 | 亚洲综合精品香蕉久久网 | 久久精品成人欧美大片 | 亚洲乱亚洲乱妇50p | 欧美国产日韩亚洲中文 | 亚洲一区二区三区香蕉 | 国产精品久久久久久亚洲影视内衣 | 波多野结衣av一区二区全免费观看 | 一本一道久久综合久久 | 漂亮人妻洗澡被公强 日日躁 | 天天做天天爱天天爽综合网 | 国产在线aaa片一区二区99 | 精品久久久中文字幕人妻 | 一本大道伊人av久久综合 | 国产成人精品一区二区在线小狼 | 狂野欧美性猛交免费视频 | 国产亚洲精品久久久ai换 | 免费人成网站视频在线观看 | 伊人色综合久久天天小片 | 国产一区二区三区四区五区加勒比 | 男女猛烈xx00免费视频试看 | 亚洲一区二区三区无码久久 | 色噜噜亚洲男人的天堂 | 丁香花在线影院观看在线播放 | 日韩精品乱码av一区二区 | 无码人妻丰满熟妇区五十路百度 | 未满小14洗澡无码视频网站 | 国产区女主播在线观看 | 少妇性俱乐部纵欲狂欢电影 | 帮老师解开蕾丝奶罩吸乳网站 | 国产激情一区二区三区 | 国产sm调教视频在线观看 | 亚洲国产av美女网站 | 天下第一社区视频www日本 | 日本精品人妻无码77777 天堂一区人妻无码 | 色综合久久网 | 一本久久a久久精品vr综合 | 国产av人人夜夜澡人人爽麻豆 | 一本久道久久综合狠狠爱 | 国产激情一区二区三区 | 日日天干夜夜狠狠爱 | 国产 浪潮av性色四虎 | 国产亚洲精品久久久久久久久动漫 | 成人无码影片精品久久久 | 一本大道伊人av久久综合 | 成人精品视频一区二区三区尤物 | 日本免费一区二区三区最新 | 国产在线精品一区二区高清不卡 | 国产成人无码午夜视频在线观看 | 高清国产亚洲精品自在久久 | 少妇性l交大片欧洲热妇乱xxx | 色情久久久av熟女人妻网站 | 老司机亚洲精品影院无码 | 强辱丰满人妻hd中文字幕 | 国产精品99久久精品爆乳 | 中文字幕乱妇无码av在线 | 亚洲精品国偷拍自产在线麻豆 | 亚洲乱码国产乱码精品精 | 亚洲成av人在线观看网址 | 人妻少妇被猛烈进入中文字幕 | 国产婷婷色一区二区三区在线 | 亚洲欧美综合区丁香五月小说 | 日本乱人伦片中文三区 | 国产九九九九九九九a片 | 在线а√天堂中文官网 | 无码av岛国片在线播放 | 日韩欧美中文字幕公布 | 国产莉萝无码av在线播放 | 日日碰狠狠丁香久燥 | 小泽玛莉亚一区二区视频在线 | 青青草原综合久久大伊人精品 | 亚洲a无码综合a国产av中文 | 亚洲欧美日韩综合久久久 | 久久视频在线观看精品 | 一本久道久久综合狠狠爱 | 亚洲精品综合五月久久小说 | 波多野结衣av一区二区全免费观看 | 国产激情无码一区二区 | 日本一卡二卡不卡视频查询 | 狠狠色噜噜狠狠狠狠7777米奇 | 欧美日韩在线亚洲综合国产人 | 国产精品99爱免费视频 | 国产特级毛片aaaaaa高潮流水 | 久久久久久a亚洲欧洲av冫 | 狠狠色色综合网站 | 夜夜夜高潮夜夜爽夜夜爰爰 | 丰满肥臀大屁股熟妇激情视频 | 中文字幕人妻丝袜二区 | 伊在人天堂亚洲香蕉精品区 | 欧美成人高清在线播放 | 午夜精品久久久内射近拍高清 | 最近的中文字幕在线看视频 | 99久久99久久免费精品蜜桃 | 少妇人妻av毛片在线看 | 女人被爽到呻吟gif动态图视看 | 伊人久久大香线焦av综合影院 | 男女猛烈xx00免费视频试看 | 妺妺窝人体色www在线小说 | 国产女主播喷水视频在线观看 | 2020久久香蕉国产线看观看 | 亚洲熟妇自偷自拍另类 | 久久久国产精品无码免费专区 | 久久久久av无码免费网 | 久久国产自偷自偷免费一区调 | 丰满少妇女裸体bbw | 樱花草在线播放免费中文 | 无码国内精品人妻少妇 | 亚洲综合精品香蕉久久网 | 玩弄少妇高潮ⅹxxxyw | 亚洲人亚洲人成电影网站色 | 精品国产麻豆免费人成网站 | 亚洲日韩乱码中文无码蜜桃臀网站 | 亚洲 另类 在线 欧美 制服 | 亚洲一区二区三区四区 | 亚洲欧美日韩综合久久久 | 中文字幕亚洲情99在线 | 精品国产一区二区三区四区在线看 | 久久久久久av无码免费看大片 | 麻豆成人精品国产免费 | 18无码粉嫩小泬无套在线观看 | 丰满少妇熟乱xxxxx视频 | 学生妹亚洲一区二区 | 国产精品高潮呻吟av久久 | 婷婷五月综合激情中文字幕 | 中文字幕无码免费久久99 | 欧美人与禽zoz0性伦交 | 丰满人妻翻云覆雨呻吟视频 | 亚洲国产成人a精品不卡在线 | 亚洲欧美中文字幕5发布 | 成人欧美一区二区三区黑人免费 | 亚洲小说春色综合另类 | 日本熟妇人妻xxxxx人hd | 亚洲精品成人福利网站 | 亚洲成a人一区二区三区 | 7777奇米四色成人眼影 | 国产精品亚洲一区二区三区喷水 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 亚洲日韩精品欧美一区二区 | 在线天堂新版最新版在线8 | 日韩少妇内射免费播放 | 久久zyz资源站无码中文动漫 | 中文字幕无码视频专区 | 少妇太爽了在线观看 | 成人免费视频视频在线观看 免费 | 久久99精品久久久久久动态图 | 又粗又大又硬毛片免费看 | 国产熟女一区二区三区四区五区 | 国产人成高清在线视频99最全资源 | 久久精品人妻少妇一区二区三区 | 狂野欧美性猛交免费视频 | 亚欧洲精品在线视频免费观看 | 一区二区三区乱码在线 | 欧洲 | 色综合久久久久综合一本到桃花网 | 久久亚洲日韩精品一区二区三区 | 国产麻豆精品一区二区三区v视界 | 性色欲网站人妻丰满中文久久不卡 | 娇妻被黑人粗大高潮白浆 | 免费人成网站视频在线观看 | 麻豆精品国产精华精华液好用吗 | 亚洲 a v无 码免 费 成 人 a v | 男女猛烈xx00免费视频试看 | 成人影院yy111111在线观看 | 狠狠亚洲超碰狼人久久 | 又湿又紧又大又爽a视频国产 | 色婷婷久久一区二区三区麻豆 | 国产精品久久久久久无码 | 欧美人与物videos另类 | 夜精品a片一区二区三区无码白浆 | 成人精品视频一区二区三区尤物 | 人人妻人人澡人人爽人人精品浪潮 | 青草青草久热国产精品 | 欧美乱妇无乱码大黄a片 | av在线亚洲欧洲日产一区二区 | 大地资源中文第3页 | 国产一区二区三区日韩精品 | 丁香花在线影院观看在线播放 | 国产激情无码一区二区app | 日本肉体xxxx裸交 | 九九在线中文字幕无码 | 影音先锋中文字幕无码 | 亚洲欧洲日本无在线码 | 欧美熟妇另类久久久久久不卡 | 人妻少妇精品无码专区二区 | 亚洲精品一区二区三区在线 | 国内精品久久毛片一区二区 | 国产在线aaa片一区二区99 | 精品国产青草久久久久福利 | 亚洲 另类 在线 欧美 制服 | 暴力强奷在线播放无码 | 国产香蕉尹人综合在线观看 | 久久婷婷五月综合色国产香蕉 | 麻豆精品国产精华精华液好用吗 | 久久精品人人做人人综合试看 | 亚洲成av人片天堂网无码】 | 在线观看欧美一区二区三区 | 久久99精品久久久久婷婷 | 在线播放无码字幕亚洲 | 国产精品内射视频免费 | 麻豆国产人妻欲求不满 | 久久亚洲国产成人精品性色 | 学生妹亚洲一区二区 | 国产欧美精品一区二区三区 | 中文字幕+乱码+中文字幕一区 | 亚洲啪av永久无码精品放毛片 | 国产亚洲精品久久久久久国模美 | 国产乱人伦偷精品视频 | 性开放的女人aaa片 | 两性色午夜视频免费播放 | 国内老熟妇对白xxxxhd | 97无码免费人妻超级碰碰夜夜 | √天堂资源地址中文在线 | 啦啦啦www在线观看免费视频 | 国产乱码精品一品二品 | 学生妹亚洲一区二区 | 国产精品无码mv在线观看 | 未满成年国产在线观看 | 全黄性性激高免费视频 | 性欧美熟妇videofreesex | 中文字幕无线码免费人妻 | 亚洲 日韩 欧美 成人 在线观看 | 人人澡人人透人人爽 | 18无码粉嫩小泬无套在线观看 | 国产成人精品无码播放 | 荫蒂被男人添的好舒服爽免费视频 | 欧美乱妇无乱码大黄a片 | 99国产欧美久久久精品 | 奇米影视7777久久精品人人爽 | 毛片内射-百度 | 久久久久久久人妻无码中文字幕爆 | 澳门永久av免费网站 | av人摸人人人澡人人超碰下载 | 一本加勒比波多野结衣 | 色婷婷综合中文久久一本 | 熟女体下毛毛黑森林 | 又黄又爽又色的视频 | 5858s亚洲色大成网站www | 99精品视频在线观看免费 | 日本精品人妻无码77777 天堂一区人妻无码 | 久久久久久国产精品无码下载 | 国产乱码精品一品二品 | 又大又黄又粗又爽的免费视频 | 亚洲狠狠色丁香婷婷综合 | 亚洲高清偷拍一区二区三区 | 亚洲国产综合无码一区 | 18精品久久久无码午夜福利 | 黑森林福利视频导航 | 亚洲精品无码国产 | 岛国片人妻三上悠亚 | 亚洲精品鲁一鲁一区二区三区 | 久久精品视频在线看15 | 亚洲中文字幕无码中字 | 国产亚洲精品精品国产亚洲综合 | 亚洲成在人网站无码天堂 | 狠狠cao日日穞夜夜穞av | 少女韩国电视剧在线观看完整 | 免费网站看v片在线18禁无码 | 人妻无码久久精品人妻 | 久久人人97超碰a片精品 | 亚洲日本一区二区三区在线 | 久久亚洲日韩精品一区二区三区 | 黄网在线观看免费网站 | 日韩欧美中文字幕在线三区 | 激情亚洲一区国产精品 | 无遮无挡爽爽免费视频 | 18禁黄网站男男禁片免费观看 | 99国产欧美久久久精品 | 亚洲 高清 成人 动漫 | 国产香蕉尹人综合在线观看 | 伦伦影院午夜理论片 | 六月丁香婷婷色狠狠久久 | 男女下面进入的视频免费午夜 | 99久久精品国产一区二区蜜芽 | 久久综合给久久狠狠97色 | 亚洲精品综合五月久久小说 | 影音先锋中文字幕无码 | 好男人社区资源 | 欧美日韩久久久精品a片 | 午夜成人1000部免费视频 | 色综合久久久无码网中文 | 性欧美videos高清精品 | 2019午夜福利不卡片在线 | 久久国产劲爆∧v内射 | 亚洲色偷偷偷综合网 | 性欧美疯狂xxxxbbbb | 欧美一区二区三区视频在线观看 | 国产人妻精品一区二区三区 | 99久久精品日本一区二区免费 | 丰满少妇熟乱xxxxx视频 | 欧美人与禽猛交狂配 | 久久成人a毛片免费观看网站 | 日本成熟视频免费视频 | 亚洲 激情 小说 另类 欧美 | www成人国产高清内射 | 午夜精品久久久内射近拍高清 | 国产精品va在线播放 | 亚洲国产精品无码一区二区三区 | 亚洲精品成a人在线观看 | 国产网红无码精品视频 | 成人aaa片一区国产精品 | 99riav国产精品视频 | 亚洲成av人片天堂网无码】 | 我要看www免费看插插视频 | 亚洲熟悉妇女xxx妇女av | 国产成人一区二区三区别 | 亚洲精品国偷拍自产在线麻豆 | 国产两女互慰高潮视频在线观看 | 任你躁国产自任一区二区三区 | 美女毛片一区二区三区四区 | 欧美35页视频在线观看 | 97精品国产97久久久久久免费 | 粉嫩少妇内射浓精videos | 亚洲精品成a人在线观看 | 国产午夜福利100集发布 | 精品国产一区二区三区四区在线看 | 丰满人妻翻云覆雨呻吟视频 | 国产精品久久久午夜夜伦鲁鲁 | 成人精品一区二区三区中文字幕 | 国产香蕉97碰碰久久人人 | 欧美肥老太牲交大战 | 亚洲aⅴ无码成人网站国产app | 亚洲 欧美 激情 小说 另类 | 国产精品欧美成人 | 成人亚洲精品久久久久软件 | 久9re热视频这里只有精品 | 精品偷拍一区二区三区在线看 | 色一情一乱一伦一视频免费看 | √8天堂资源地址中文在线 | 亚洲一区二区观看播放 | 国产电影无码午夜在线播放 | 成人无码精品1区2区3区免费看 | 永久免费观看国产裸体美女 | 激情内射亚州一区二区三区爱妻 | 澳门永久av免费网站 | 国精品人妻无码一区二区三区蜜柚 | 亚洲熟妇色xxxxx欧美老妇 | 国产精品亚洲综合色区韩国 | 亚洲综合伊人久久大杳蕉 | 久久久久99精品成人片 | 亚洲欧美国产精品专区久久 | 久久国产精品偷任你爽任你 | 美女扒开屁股让男人桶 | 曰本女人与公拘交酡免费视频 | 亚洲精品成a人在线观看 | 夜夜影院未满十八勿进 | 任你躁国产自任一区二区三区 | 风流少妇按摩来高潮 | 亚洲成av人影院在线观看 | 久久99精品久久久久久动态图 | 久久久久免费看成人影片 | 性做久久久久久久久 | 性生交大片免费看l | 久久综合香蕉国产蜜臀av | 高潮喷水的毛片 | 欧洲熟妇色 欧美 | 国产亚洲欧美日韩亚洲中文色 | 男女超爽视频免费播放 | 无码乱肉视频免费大全合集 | 西西人体www44rt大胆高清 | 麻花豆传媒剧国产免费mv在线 | 国产精品国产自线拍免费软件 | 网友自拍区视频精品 | 沈阳熟女露脸对白视频 | av无码电影一区二区三区 | 丁香啪啪综合成人亚洲 | 国产人妻精品一区二区三区不卡 | 欧美成人高清在线播放 | 亚洲码国产精品高潮在线 | 亚洲人成网站在线播放942 | 亚洲国产欧美日韩精品一区二区三区 | 国产午夜无码精品免费看 | 人妻无码αv中文字幕久久琪琪布 | 成熟妇人a片免费看网站 | 日本护士xxxxhd少妇 | 麻豆蜜桃av蜜臀av色欲av | 麻豆精品国产精华精华液好用吗 | 九九综合va免费看 | 97无码免费人妻超级碰碰夜夜 | 国内揄拍国内精品少妇国语 | 波多野结衣 黑人 | 国产成人无码a区在线观看视频app | 久久精品丝袜高跟鞋 | 久久99国产综合精品 | 亚洲一区av无码专区在线观看 | 久久精品女人的天堂av | 日本饥渴人妻欲求不满 | 亚洲精品中文字幕久久久久 | 人妻插b视频一区二区三区 | 国产九九九九九九九a片 | 色情久久久av熟女人妻网站 | 麻豆人妻少妇精品无码专区 | 日韩欧美中文字幕在线三区 | 激情五月综合色婷婷一区二区 | 亚洲精品中文字幕乱码 | 99久久人妻精品免费二区 | 国产亚洲精品久久久久久国模美 | 人人爽人人爽人人片av亚洲 | 国产精品亚洲专区无码不卡 | 国内老熟妇对白xxxxhd | 亚洲中文字幕在线无码一区二区 | 女人被男人爽到呻吟的视频 | 国产深夜福利视频在线 | 国产又爽又猛又粗的视频a片 | 亚洲色无码一区二区三区 | 久久综合狠狠综合久久综合88 | 欧美性黑人极品hd | 亚洲熟妇色xxxxx亚洲 | 欧美喷潮久久久xxxxx | 欧美国产亚洲日韩在线二区 | 欧美熟妇另类久久久久久多毛 | 日本精品少妇一区二区三区 | 久久久中文字幕日本无吗 | 无码国内精品人妻少妇 | 人人妻人人澡人人爽欧美精品 | 麻豆成人精品国产免费 | 最新版天堂资源中文官网 | 牲欲强的熟妇农村老妇女 | 亚洲自偷自偷在线制服 | 国产成人午夜福利在线播放 | 俺去俺来也在线www色官网 | 99久久婷婷国产综合精品青草免费 | 漂亮人妻洗澡被公强 日日躁 | 国产无av码在线观看 | 人人超人人超碰超国产 | 欧美人与禽zoz0性伦交 | 人人妻人人藻人人爽欧美一区 | 亚洲综合伊人久久大杳蕉 | 欧美老人巨大xxxx做受 | 伊人色综合久久天天小片 | 国产人妻久久精品二区三区老狼 | 兔费看少妇性l交大片免费 | 我要看www免费看插插视频 | 国产莉萝无码av在线播放 | 精品久久久久香蕉网 | 欧美黑人巨大xxxxx | 国产精品亚洲一区二区三区喷水 | 欧美亚洲日韩国产人成在线播放 | 欧美性猛交内射兽交老熟妇 | 久久综合香蕉国产蜜臀av | 中文精品无码中文字幕无码专区 | 老子影院午夜精品无码 | 亚洲欧美综合区丁香五月小说 | 欧美午夜特黄aaaaaa片 | 丰满诱人的人妻3 | 超碰97人人做人人爱少妇 | 青青久在线视频免费观看 | 亚洲精品国产精品乱码不卡 | 台湾无码一区二区 | 又大又硬又黄的免费视频 | 精品无码国产自产拍在线观看蜜 | 高清国产亚洲精品自在久久 | 国产午夜亚洲精品不卡下载 | 性色欲网站人妻丰满中文久久不卡 | 国产亲子乱弄免费视频 | 久久久亚洲欧洲日产国码αv | 色综合久久久无码中文字幕 | 久久精品成人欧美大片 | 久久精品国产亚洲精品 | 天海翼激烈高潮到腰振不止 | 中文毛片无遮挡高清免费 | 一二三四社区在线中文视频 | 午夜无码人妻av大片色欲 | 成人无码精品一区二区三区 | 人人妻人人澡人人爽欧美一区九九 | 最近中文2019字幕第二页 | 欧美亚洲国产一区二区三区 | 欧美丰满熟妇xxxx性ppx人交 | 最近中文2019字幕第二页 | 人妻少妇精品无码专区二区 | 国产成人精品无码播放 | 国产成人综合在线女婷五月99播放 | 欧美老人巨大xxxx做受 | 男人和女人高潮免费网站 | 日本精品久久久久中文字幕 | 久久伊人色av天堂九九小黄鸭 | 蜜桃臀无码内射一区二区三区 | 国产精品99爱免费视频 | 国产精品第一区揄拍无码 | 丰满少妇弄高潮了www | 无码毛片视频一区二区本码 | 国产精品对白交换视频 | 国产精品资源一区二区 | 又大又黄又粗又爽的免费视频 | 奇米影视7777久久精品人人爽 | 国产午夜无码视频在线观看 | 亚洲s色大片在线观看 | 精品国产成人一区二区三区 | 免费国产黄网站在线观看 | 国产内射爽爽大片视频社区在线 | 国产真实伦对白全集 | 国产色视频一区二区三区 | 欧美xxxx黑人又粗又长 | 精品国产麻豆免费人成网站 | 97夜夜澡人人双人人人喊 | 综合人妻久久一区二区精品 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 国产一区二区三区日韩精品 | 98国产精品综合一区二区三区 | 亚洲熟妇色xxxxx亚洲 | 妺妺窝人体色www在线小说 | 天天做天天爱天天爽综合网 | 无码乱肉视频免费大全合集 | 亚洲精品无码人妻无码 | 国产麻豆精品一区二区三区v视界 | 久久久无码中文字幕久... | 97精品人妻一区二区三区香蕉 | 一本久久a久久精品亚洲 | 国内综合精品午夜久久资源 | 99久久久无码国产aaa精品 | 欧美怡红院免费全部视频 | 波多野结衣av在线观看 | 亚洲春色在线视频 | 国产成人无码av在线影院 | 亚洲国产欧美在线成人 | 欧美日韩综合一区二区三区 | 成人一在线视频日韩国产 | 国产莉萝无码av在线播放 | 日本一区二区三区免费播放 | 欧美人与禽猛交狂配 | 福利一区二区三区视频在线观看 | 色婷婷综合中文久久一本 | 免费观看黄网站 | 国产精品第一国产精品 | 在教室伦流澡到高潮hnp视频 | 伊人久久大香线蕉av一区二区 | 亚洲 另类 在线 欧美 制服 | 中文字幕无码av激情不卡 | 国产精品无码成人午夜电影 | 四虎4hu永久免费 | 国产av人人夜夜澡人人爽麻豆 | 国产精品久久久久影院嫩草 | 欧美日韩综合一区二区三区 | 色婷婷综合中文久久一本 | 中文字幕无码av激情不卡 | 在教室伦流澡到高潮hnp视频 | 亚洲无人区一区二区三区 | 国产精品对白交换视频 | 小鲜肉自慰网站xnxx | 国产成人人人97超碰超爽8 | 欧美人与物videos另类 | 国精产品一区二区三区 | 丰满人妻翻云覆雨呻吟视频 | 乱人伦人妻中文字幕无码久久网 | 欧美黑人性暴力猛交喷水 | 午夜免费福利小电影 | 国产又爽又猛又粗的视频a片 | 大屁股大乳丰满人妻 | 国产人妻久久精品二区三区老狼 | 人人妻人人澡人人爽人人精品浪潮 | 无套内射视频囯产 | 永久免费观看美女裸体的网站 | 红桃av一区二区三区在线无码av | 乱人伦中文视频在线观看 | 成人精品一区二区三区中文字幕 | 天海翼激烈高潮到腰振不止 | 日韩av无码一区二区三区 | 老熟女乱子伦 | 高潮毛片无遮挡高清免费视频 | 免费看少妇作爱视频 | 免费无码的av片在线观看 | 国产成人精品视频ⅴa片软件竹菊 | 一本久道久久综合狠狠爱 | 精品少妇爆乳无码av无码专区 | √8天堂资源地址中文在线 | 久久久婷婷五月亚洲97号色 | 国产精品va在线观看无码 | 波多野结衣av在线观看 | 又大又硬又黄的免费视频 | 激情爆乳一区二区三区 | 精品国产av色一区二区深夜久久 | 亚洲 另类 在线 欧美 制服 | 午夜无码区在线观看 | 亚洲天堂2017无码中文 | 国产偷抇久久精品a片69 | 亚洲国产综合无码一区 | 麻豆蜜桃av蜜臀av色欲av | 少妇性l交大片欧洲热妇乱xxx | 久久zyz资源站无码中文动漫 | 国产av一区二区三区最新精品 | 久久人妻内射无码一区三区 | 日本一区二区更新不卡 | 日韩在线不卡免费视频一区 | 高潮毛片无遮挡高清免费 | 男人扒开女人内裤强吻桶进去 | 国产又粗又硬又大爽黄老大爷视 | 国产精品无码一区二区桃花视频 | 伊人色综合久久天天小片 | 综合激情五月综合激情五月激情1 | 国产亚洲tv在线观看 | 日本熟妇大屁股人妻 | 少妇人妻大乳在线视频 | 亚洲一区二区三区 | 亚洲人交乣女bbw | 久热国产vs视频在线观看 | 欧美黑人性暴力猛交喷水 | 日本va欧美va欧美va精品 | 国产精品视频免费播放 | 亚洲精品国产第一综合99久久 | 国产精品亚洲专区无码不卡 | 欧美精品在线观看 | 国产成人无码专区 | 真人与拘做受免费视频 | 九九久久精品国产免费看小说 | 婷婷五月综合激情中文字幕 | 日韩精品乱码av一区二区 | a国产一区二区免费入口 | 色欲av亚洲一区无码少妇 | 精品一区二区不卡无码av | 日本在线高清不卡免费播放 | 久久99精品久久久久久 | 国产欧美亚洲精品a | 亚洲精品久久久久avwww潮水 | 国产色精品久久人妻 | 波多野结衣 黑人 | 丰满妇女强制高潮18xxxx | 99久久久无码国产精品免费 | 99久久人妻精品免费一区 | 日本精品人妻无码77777 天堂一区人妻无码 | 欧美日韩久久久精品a片 | 亚洲精品久久久久久一区二区 | 国产人妻精品午夜福利免费 | 亚洲国产日韩a在线播放 | 精品国偷自产在线视频 | 亚洲色欲色欲欲www在线 | 亚洲精品成人福利网站 | 无码国内精品人妻少妇 | 精品日本一区二区三区在线观看 | 国产小呦泬泬99精品 | 小sao货水好多真紧h无码视频 | 欧美性色19p | 国产超级va在线观看视频 | 精品乱码久久久久久久 | 一本无码人妻在中文字幕免费 | 亚洲人成影院在线无码按摩店 | 人妻熟女一区 | 亚洲一区二区三区播放 | 亚洲一区二区三区播放 | 黑人巨大精品欧美黑寡妇 | 波多野结衣 黑人 | 中文字幕乱码人妻无码久久 | 亚洲国产精品一区二区美利坚 | 日本一卡2卡3卡四卡精品网站 | 午夜精品久久久内射近拍高清 | 国产免费久久久久久无码 | 伊人色综合久久天天小片 | 成在人线av无码免观看麻豆 | 欧美色就是色 | 亚洲中文字幕无码一久久区 | 特大黑人娇小亚洲女 | 国产国产精品人在线视 | 欧美黑人巨大xxxxx | 中文字幕无码热在线视频 | 东京热无码av男人的天堂 | 国产特级毛片aaaaaaa高清 | 国产精品igao视频网 | 四虎国产精品一区二区 | 国产精品亚洲а∨无码播放麻豆 | 亚洲成色www久久网站 | 日韩亚洲欧美中文高清在线 | 伊在人天堂亚洲香蕉精品区 | 无码午夜成人1000部免费视频 | 伊在人天堂亚洲香蕉精品区 | 中文字幕无码日韩欧毛 | 国产艳妇av在线观看果冻传媒 | 1000部啪啪未满十八勿入下载 | 天下第一社区视频www日本 | 巨爆乳无码视频在线观看 | 精品厕所偷拍各类美女tp嘘嘘 | 中文无码成人免费视频在线观看 | 少妇邻居内射在线 | 日日橹狠狠爱欧美视频 | 亚洲毛片av日韩av无码 | 国产又爽又黄又刺激的视频 | 日韩精品无码一区二区中文字幕 | 久久久久成人精品免费播放动漫 | 又大又紧又粉嫩18p少妇 | 免费人成网站视频在线观看 | 国产精品亚洲а∨无码播放麻豆 | 国内精品人妻无码久久久影院蜜桃 | 麻豆国产丝袜白领秘书在线观看 | 永久黄网站色视频免费直播 | 天天摸天天透天天添 | 成人欧美一区二区三区 | 亚洲爆乳无码专区 | 偷窥日本少妇撒尿chinese | 亚洲 高清 成人 动漫 | 国产xxx69麻豆国语对白 | 成人一在线视频日韩国产 | 亚洲一区二区三区在线观看网站 | 久久亚洲中文字幕无码 | 狠狠色噜噜狠狠狠7777奇米 | 亚洲精品一区二区三区在线 | 久久精品人人做人人综合 | 中文字幕人成乱码熟女app | 男人的天堂2018无码 | 日韩欧美成人免费观看 | www国产亚洲精品久久网站 | 无码播放一区二区三区 | 久久久久免费精品国产 | 天天综合网天天综合色 | 国产精品亚洲专区无码不卡 | 2020久久香蕉国产线看观看 | 国产熟妇高潮叫床视频播放 | √天堂资源地址中文在线 | 亚洲狠狠婷婷综合久久 | 色窝窝无码一区二区三区色欲 | 久久久久99精品国产片 | 亚洲第一无码av无码专区 | 日日碰狠狠躁久久躁蜜桃 | 国产免费久久久久久无码 | 久久亚洲国产成人精品性色 | 麻花豆传媒剧国产免费mv在线 | 奇米影视888欧美在线观看 | 丝袜人妻一区二区三区 | 在线精品国产一区二区三区 | 午夜熟女插插xx免费视频 | 大色综合色综合网站 | 色五月丁香五月综合五月 | 欧美性猛交内射兽交老熟妇 | 好屌草这里只有精品 | 欧美高清在线精品一区 | 国产午夜福利100集发布 | 人妻尝试又大又粗久久 | 内射爽无广熟女亚洲 | 亚洲成av人片天堂网无码】 | 激情五月综合色婷婷一区二区 | 成年女人永久免费看片 | 人人妻人人澡人人爽欧美一区九九 | 色综合久久久无码中文字幕 | 久久久久亚洲精品男人的天堂 | 久久午夜无码鲁丝片 | 狠狠躁日日躁夜夜躁2020 | 国产无套内射久久久国产 | 色婷婷综合中文久久一本 | 国产人妻人伦精品 | 综合激情五月综合激情五月激情1 | 亚洲精品国偷拍自产在线麻豆 | 国产乱人伦偷精品视频 | 亚洲国产精品久久人人爱 | 丰满少妇弄高潮了www | 国产精品资源一区二区 | 国产亚洲精品久久久久久 | 偷窥村妇洗澡毛毛多 | av小次郎收藏 | 无码一区二区三区在线 | 亚洲国产精品无码久久久久高潮 | 国产av人人夜夜澡人人爽麻豆 | 天堂一区人妻无码 | 国色天香社区在线视频 | 精品无码成人片一区二区98 | 无码国产乱人伦偷精品视频 | 国产成人一区二区三区别 | 大乳丰满人妻中文字幕日本 | 国产成人av免费观看 | 97久久精品无码一区二区 | 少妇高潮喷潮久久久影院 | 黑人巨大精品欧美一区二区 | 国产精品鲁鲁鲁 | 亚洲综合精品香蕉久久网 | 天堂一区人妻无码 | 成人精品视频一区二区 | 免费国产成人高清在线观看网站 | 乱人伦中文视频在线观看 | 在线观看免费人成视频 | √8天堂资源地址中文在线 | 国产精品办公室沙发 | 精品熟女少妇av免费观看 | 国产成人精品一区二区在线小狼 | 大地资源网第二页免费观看 | 久久人人爽人人爽人人片av高清 | 亚洲日本va中文字幕 | 午夜男女很黄的视频 | 亚洲国产日韩a在线播放 | 人妻少妇精品视频专区 | 国产午夜无码精品免费看 | 国产成人无码av一区二区 | 国产午夜福利100集发布 | 国产精品久久久久久久影院 | 波多野结衣 黑人 | 欧美日韩一区二区三区自拍 | 呦交小u女精品视频 | 久久午夜夜伦鲁鲁片无码免费 | 成年女人永久免费看片 | 国产97人人超碰caoprom | 大地资源网第二页免费观看 | 国产午夜手机精彩视频 | 少妇久久久久久人妻无码 | 在线a亚洲视频播放在线观看 | 激情五月综合色婷婷一区二区 | 98国产精品综合一区二区三区 | 最新国产乱人伦偷精品免费网站 | 亚洲一区二区三区播放 | 精品偷拍一区二区三区在线看 | 精品欧美一区二区三区久久久 | 少妇久久久久久人妻无码 | 精品久久久无码人妻字幂 | 国产精华av午夜在线观看 | 好男人www社区 | 狠狠色欧美亚洲狠狠色www | 玩弄中年熟妇正在播放 | 蜜臀av无码人妻精品 | 欧美高清在线精品一区 | 亚洲国产一区二区三区在线观看 | 最新国产乱人伦偷精品免费网站 | 成人无码视频免费播放 | 熟妇女人妻丰满少妇中文字幕 | 久久精品女人的天堂av | 中文字幕 亚洲精品 第1页 | 精品 日韩 国产 欧美 视频 | 国产亚洲精品久久久ai换 | 亚洲欧美日韩国产精品一区二区 | 伊人久久大香线蕉av一区二区 | 亚洲中文字幕无码一久久区 | 伊人久久婷婷五月综合97色 | 久久精品人妻少妇一区二区三区 | 夫妻免费无码v看片 | 男女性色大片免费网站 | 久久精品中文字幕大胸 | 久久久www成人免费毛片 | 亚洲国产精华液网站w | 久久aⅴ免费观看 | 久久99精品久久久久久 | 久久国产自偷自偷免费一区调 | 天天综合网天天综合色 | 精品国产一区二区三区av 性色 | 伊人久久大香线蕉亚洲 | 无码人妻丰满熟妇区五十路百度 | 久久久国产一区二区三区 | 又湿又紧又大又爽a视频国产 | 激情综合激情五月俺也去 | 国产午夜亚洲精品不卡下载 | 亚洲欧美精品伊人久久 | 国产精品成人av在线观看 | 亚洲熟妇色xxxxx欧美老妇y | 久久精品99久久香蕉国产色戒 | 在线天堂新版最新版在线8 | 奇米影视7777久久精品 | 精品偷拍一区二区三区在线看 | 国产精品无码一区二区三区不卡 | 国产免费观看黄av片 | 成人免费视频在线观看 | 东京热一精品无码av | 日韩人妻系列无码专区 | 国产精品久久久久久亚洲影视内衣 | 午夜理论片yy44880影院 | 夜夜躁日日躁狠狠久久av | 嫩b人妻精品一区二区三区 | 日本xxxx色视频在线观看免费 | 久久精品国产99久久6动漫 | 国产亚洲视频中文字幕97精品 | 98国产精品综合一区二区三区 | 亚洲中文无码av永久不收费 | 久久aⅴ免费观看 | 少妇无码av无码专区在线观看 | 7777奇米四色成人眼影 | 日本xxxx色视频在线观看免费 | 亚拍精品一区二区三区探花 | 精品国精品国产自在久国产87 | 免费无码肉片在线观看 | 欧美真人作爱免费视频 | 久久天天躁狠狠躁夜夜免费观看 | 亚洲国产av美女网站 | 中文字幕无码乱人伦 | 在线欧美精品一区二区三区 | 又粗又大又硬毛片免费看 | 六月丁香婷婷色狠狠久久 | 国产激情综合五月久久 | 中文久久乱码一区二区 | 午夜成人1000部免费视频 | 日日碰狠狠丁香久燥 | 亚洲 激情 小说 另类 欧美 | 男女作爱免费网站 | 99精品视频在线观看免费 | 国产av剧情md精品麻豆 | 久久久精品人妻久久影视 | 永久免费观看国产裸体美女 | 国产av人人夜夜澡人人爽麻豆 | 欧美国产日韩亚洲中文 | 青青久在线视频免费观看 | 激情五月综合色婷婷一区二区 | 国产av剧情md精品麻豆 | 欧美一区二区三区 | 日韩视频 中文字幕 视频一区 | 高潮毛片无遮挡高清免费 | 久久久久久久人妻无码中文字幕爆 | 最新版天堂资源中文官网 | 亚洲一区二区三区香蕉 | 久久综合九色综合欧美狠狠 | 亚洲小说图区综合在线 | 日本乱偷人妻中文字幕 | 高清不卡一区二区三区 | 麻豆av传媒蜜桃天美传媒 | 亚洲成a人片在线观看无码3d | 少妇厨房愉情理9仑片视频 | 18黄暴禁片在线观看 | 狠狠躁日日躁夜夜躁2020 | 无码福利日韩神码福利片 | 国产又粗又硬又大爽黄老大爷视 | 成人精品视频一区二区 | 亚洲熟女一区二区三区 | 无码福利日韩神码福利片 | 欧美野外疯狂做受xxxx高潮 | 影音先锋中文字幕无码 | 精品aⅴ一区二区三区 | 99精品久久毛片a片 | 亚洲熟妇自偷自拍另类 | 亚洲自偷自偷在线制服 | 日本精品久久久久中文字幕 | 99久久精品午夜一区二区 | 欧美兽交xxxx×视频 | 牲交欧美兽交欧美 | 国产高清不卡无码视频 | 国产区女主播在线观看 | 中文字幕乱码亚洲无线三区 | 性生交大片免费看女人按摩摩 | 久久综合网欧美色妞网 | 亚洲中文字幕在线无码一区二区 | 亚洲va中文字幕无码久久不卡 | 377p欧洲日本亚洲大胆 | 无码人妻av免费一区二区三区 | 丁香花在线影院观看在线播放 | 99久久久无码国产aaa精品 | 国产香蕉97碰碰久久人人 | 帮老师解开蕾丝奶罩吸乳网站 | 中文无码伦av中文字幕 | 国产午夜无码视频在线观看 | 久久综合给久久狠狠97色 | 日韩精品无码一区二区中文字幕 | 亚洲一区二区三区无码久久 | 性做久久久久久久久 | 成人试看120秒体验区 | 男女猛烈xx00免费视频试看 | 国产两女互慰高潮视频在线观看 | 国产亲子乱弄免费视频 | 欧美日韩视频无码一区二区三 | 亚拍精品一区二区三区探花 | 久久视频在线观看精品 | 性欧美大战久久久久久久 | 国产另类ts人妖一区二区 | 亚洲精品久久久久avwww潮水 | 欧美性生交xxxxx久久久 | 性啪啪chinese东北女人 | 欧美午夜特黄aaaaaa片 | 偷窥村妇洗澡毛毛多 | 狠狠色欧美亚洲狠狠色www | 亚洲自偷精品视频自拍 | 性做久久久久久久免费看 | 国产成人精品优优av | 亚洲国产欧美日韩精品一区二区三区 | 日本熟妇人妻xxxxx人hd | 国产va免费精品观看 | 亚洲狠狠色丁香婷婷综合 | 日韩精品无码免费一区二区三区 | 强伦人妻一区二区三区视频18 | 性欧美熟妇videofreesex | 4hu四虎永久在线观看 | 欧美亚洲国产一区二区三区 | 中文字幕人妻无码一区二区三区 | 成人无码视频在线观看网站 | 无码任你躁久久久久久久 | 国产福利视频一区二区 | 亚洲精品成人福利网站 | 99精品国产综合久久久久五月天 | 亚洲精品午夜无码电影网 | 国产精品嫩草久久久久 | 中文字幕av伊人av无码av | 人妻互换免费中文字幕 | 欧美 日韩 人妻 高清 中文 | 一本大道伊人av久久综合 | 久久99精品国产.久久久久 | 国产精品久久久久久久影院 | 女高中生第一次破苞av | 免费网站看v片在线18禁无码 | 精品aⅴ一区二区三区 |