Python 获取起止日期段中的时间列表

咱们新建一个Python文件之后,都用这个main方法来调用自己的方法体哈:

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

为了调用datetime等这些已有的库,你需要在文件最上方加入引用语句:

import time
from datetime import datetime, timedelta

Method 1. 获取起止日期时间段的所有时间列表:

# 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获取起止日期时间段的所有工作日(周一到周五) 时间列表:

需要在文件最上方加入pandas库:

import pandas as pd

当然前提是你本机已经安装了pandas这个神奇的库,如果没有,就进入cmd,然后执行如下自动安装命令:

pip install pandas

如果pip都没有安装的话,需要先安装pip(python的Library自动安装工具):

装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哈哈~

猜你喜欢

转载自my.oschina.net/u/942203/blog/1623083