0

我正在写一个 python 作业,我们正在写酒店客户的房间预订。我们应该比较到达和离开的日期。如果出发日期早于到达日期,它将打印错误消息,但运行后我一直收到错误消息。我不知道为什么....我正在尝试制作该客户信息的命名元组,即

Reservation=namedtuple('Reservation','确认房间号_到达_日期_出发_日期名称)

所以我取出了到达日期(2008 年 10 月 13 日),因为它是一个字符串,所以我将它拆分。我试图将所有数字组合成一个整数。之后......我使用日期时间......是的......似乎我在这里做错了什么。我不明白错误的含义: Invalid literal for int() with base 10

这是我的程序:

    elif lst[0]=='LR':
        for r in new_reservation_list:
            for d in r.arrive_date:
                lsst=d.split()
                month1=lsst[:2]
                months=int(''.join([str(x) for x in month1]))
                date1=lsst[3:5]
                dates=int(''.join(([str(x) for x in date1])))
                year1=lsst[7:]
                years=int(''.join(([str(x) for x in year1])))
            arrive_date1=datetime.date(int(months),int(dates),int(years))
            for e in r.depart_date:
                lstt=e.split()
                month2=lsst[:2]
                months2=int(''.join([str(x) for x in month2]))
                date2=lsst[3:5]
                dates2=int(''.join(([str(x) for x in date2])))
                year2=lsst[7:]
                years2=int(''.join(([str(x) for x in year2])))
            depart_date1=datetime.date(int(months2),int(dates2),int(years2))
            if arrive_date>depart_date==True:
                print('Sorry, can''t reserve room', r.room_number,' (',r.arrive_date,' to ',r.depart_date,'); can''t leave before you arrive.')
            elif lst[1] in new_reservation_list:
                    print('Sorry, can''t reserve room ',r.room_number, ' (',r.arrive_date,' to ',r.depart_date,'); it''s already booked (Conf. #',r.confirmation_number)
            else:
                print('Reserving room',r.room_number,'for',r.name,'-- Confirmation #',r.confirmation_number,'\n       ','arriving',r.arrive_date,', departing ',r.depart_date)
                print('{:5}{:8}{:16}{:15}{:25}'.format('No.','Rm.','Arrive','Depart','Guest'))
                print('{:5}{:4}{:12}{:12}{:17}'.format(r.confirmation_number,r.room_number,r.arrive_date,r.depart_date, r.name))
4

1 回答 1

2

检查时间模块中的strptime函数。您可以使用此功能转换日期并进行比较。

于 2013-03-14T07:08:24.463 回答