问题描述
我有一些 .ini "yyyymmdd" 格式的日期。
我的 .ini 文件详细信息:
[global]
date_with_interval = 20210311:3,20200228:4
在上面的这个变量中,我有两个以冒号分隔的值,第一个是日期和第二个间隔 所以基于需要获取一个日期序列的间隔值,如
#I need the output in this format
output = [[20210311,20210312,20210312],[20200228,20200229,20200301,20200302]]
我已经尝试过这种方式,但遗漏了一些要点。
import configparser
config_file= "file1.ini"
con.read(config_file)
def read(name):
return con.get('global',name)
valid_date = []
data_date = read("date_with_interval")
date_info = data_date.split(",")
for date in date_info:
date_format,interval = date.split(":")
print("Date is:",date_format)
print("Interval",interval)
year,month,dd = date_format[0:4],date_format[4:6],date_format[6:8]
print("year",year)
print("month",month)
print("date",dd)
解决方法
可能想使用 datetime
模块来添加这样的时间增量:
import datetime
date_with_interval = ['20210311:3','20200228:4']
output = []
for x in date_with_interval:
t = []
d,n = x.split(':')
n = int(n)
for i in range(n):
t.append(datetime.datetime.strftime(datetime.datetime.strptime(d,"%Y%m%d")+datetime.timedelta(days=i),"%Y%m%d"))
output.append(t)
输出
[['20210311','20210312','20210313'],['20200228','20200229','20200301','20200302']]