Python 獲取起止日期段中的時間列表

我們新建一個Python文件以後,都用這個main方法來調用本身的方法體哈:html

if __name__ == "__main__":
    print get_date_list('2018-01-01', '2018-02-28')

爲了調用datetime等這些已有的庫,你須要在文件最上方加入引用語句:python

import time
from datetime import datetime, timedelta

 

Method 1. 獲取起止日期時間段的全部時間列表:app

# Get date list from begin_date to end_date
def get_date_list(begin_date, end_date):
    dates = []
    # Get the time tuple : dt
    dt = datetime.strptime(begin_date, "%Y-%m-%d")
    date = begin_date[:]
    while date <= end_date:
        dates.append(date)
        dt += timedelta(days=1)
        date = dt.strftime("%Y-%m-%d")
    return dates

Method 2. 獲取起止日期時間段的全部工做日 (週一到週五) 時間列表:函數

# Get date list from begin_date to end_date
def get_date_list(begin_date, end_date):
    dates = []
    # Get the time tuple : dt
    dt = datetime.strptime(begin_date, "%Y-%m-%d")
    date = begin_date[:]
    while date <= end_date:
        if dt.strftime("%w") in ["1", "2", "3", "4", "5"]:
            dates.append(date)
        dt += timedelta(days=1)
        date = dt.strftime("%Y-%m-%d")
    return dates

Method 3. 獲取起止日期時間段的全部雙休日 (週六和週日) 時間列表:工具

# Get date list from begin_date to end_date
def get_date_list(begin_date, end_date):
    dates = []
    # Get the time tuple : dt
    dt = datetime.strptime(begin_date, "%Y-%m-%d")
    date = begin_date[:]
    while date <= end_date:
        if dt.strftime("%w") in ["6", "0"]:
            dates.append(date)
        dt += timedelta(days=1)
        date = dt.strftime("%Y-%m-%d")
    return dates

Method 4. 用pandas獲取起止日期時間段的全部工做日(週一到週五) 時間列表:spa

須要在文件最上方加入pandas庫:命令行

import pandas as pd

固然前提是你本機已經安裝了pandas這個神奇的庫,若是沒有,就進入cmd,而後執行以下自動安裝命令:htm

pip install pandasblog

若是pip都沒有安裝的話,須要先安裝pip(python的Library自動安裝工具):ip

裝pip的方式一:

在網上下載pip壓縮文件,而後cmd命令行解壓縮安裝:

# tar -xzvf pip-1.5.4.tar.gz

# cd pip-1.5.4

# python setup.py install

裝pip的方式二:

不用下載pip文件,直接在cmd命令行執行easy_install.exe pip安裝:

python27\Scripts文件夾下會出現一系列和pip有關的文件,其中有pip.exe,說明pip命令能夠使用:

在cmd下輸入「pip」,若是能識別"pip"指令,則說明pip安裝成功了。

也就是說會出現以下的畫面:

 

若是全部的都裝好了,直接在python文件中引用pandas來實現上述代碼只須要簡單的一行:

def get_date_list(start, end):
    date_list = [d.strftime("%Y-%m-%d") for d in pd.date_range(start, end, freq="B")]
    return date_list

Method 5. 用pandas獲取起止日期時間段的全部月末時間列表(僅僅須要修改freq):

def get_date_list(start, end):
    date_list = [d.strftime("%Y-%m-%d") for d in pd.date_range(start, end, freq="M")]
    return date_list

 

Comments:

若是你對方法中的一些內置函數不是很是明白,例如"datetime.strptime" 和「strftime」的用法,你能夠參照以下貼子:

https://www.cnblogs.com/pingqiang/p/7812137.html 

謝謝閱讀,O(∩_∩)O哈哈~

相關文章
相關標籤/搜索