我需要解析包含时间跨度的字符串,例如:
周四6:30-7:30
2009年12月30日 - 2010年1月1日
1月15日下午7:30至8:30
周四,从6:30到7:30
和别的...
添加
6:30到7:30
和日期/时间,例如Word的insert-> date可以生成的大多数情况
如果有任何内容涵盖了我需要涵盖的所有案例,我会感到非常惊讶,我正在寻找语法来开始.
好的,以下语法解析您的示例中的任何内容:
DTExp = Day, ['-', Day] Day = DayExp, [[','], ['from'], TimeRange] DayExp = WeekDay | [Weekday], Month, DayNumber, [[','], YearNumber] | [Weekday], MonthNumber, '/', DayNumber, ['/', YearNumber] TimeRange = Time, [['-'|'to'] Time] Time = HourNumber, ':', MinuteNumber, ['AM'|'PM'] WeekDay = 'monday' | 'tuesday' | ... Month = MonthNumber | MonthName MonthName = 'january' | 'february' | ... DayNumber = Number MonthNumber = Number YearNumber = Number, ['AD'|'BC'] HourNumber = Number MinuteNumber = Number
语法有一点问题.如果读取DayExp,然后是时间和' - ',那么您可以期待另一个DayExp或其他时间.但这是通过前瞻解决的,因为如果是时间,则数字后面跟一个':'.
让我们尝试构建一个解析树:
Thursday 6 : 30 - 7 : 30 AM | | | | | | WeekDay Number : Number - Number : Number | | -----|---- -----|----------- | Time - Time | ---------|--------- DayExp TimeRange ----------|----------- Day | DTExp