datetime - 时间/日期范围语法

标签 datetime parsing grammar timespan

我需要解析包含时间跨度的字符串,例如:

  • 周四上午 6:30-7:30
  • 2009年12月30日 - 2010年1月1日
  • 2009 年 1 月 15 日晚上 7:30 至 8:30
  • 周四上午 6:30 至 7:30
  • 还有其他人...

已添加

  • 6:30 至 7:30

和日期/时间,例如 Word 的插入->日期可以生成的大多数情况

如果有任何内容涵盖了我需要涵盖的所有情况,我会感到非常惊讶,因此我正在寻找语法作为起点。

最佳答案

好的,以下语法会解析示例中的所有内容:

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

关于datetime - 时间/日期范围语法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/517489/

相关文章:

c# - DateTime 解析 WinRT Windows 8 RTM 中的错误?

ios - 从电话号码确定国际电话代码的算法

javascript - 访问名称具有特殊字符的字段

mysql - 时间戳略有不同的 2 个不同数据库中的表之间的连接 (MySQL)

javascript - 将时间戳转换为日期会在结果中给出不同的时区吗?

c# - 在 .NET 中构建解析器的 goto 方法是什么

grammar - 简明英语的乔姆斯基层次结构

parsing - 左结合与左递归

Javascript。将日期时间转换为漂亮的日期。奇怪的格式

parsing - Jqmath - 页面加载后应用