You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

134 lines
4.0 KiB

7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
  1. import argparse
  2. from print2d import print2d
  3. import re
  4. import ctabus
  5. from dateutil.parser import parse as date_parse
  6. import datetime
  7. import sys
  8. import os.path as osp
  9. from search import Search,StopSearch
  10. def numb_sort(str):
  11. n = 40
  12. try:
  13. return re.sub(r'\d+',lambda match: match.group(0).rjust(n,'0'),str)
  14. except Exception as E:
  15. print(str)
  16. raise E
  17. def pprint_delta(delta):
  18. delta = str(delta)
  19. days= None
  20. s1 = delta.split(', ')
  21. if len(s1) > 1:
  22. days,time = s1
  23. else:
  24. time = s1[0]
  25. time = time.split('.')[0]
  26. hour,minute,second = map(int,time.split(':'))
  27. time = ''
  28. if hour:
  29. time += f'{hour} hour' + ('s' if hour != 1 else '')
  30. if minute:
  31. if time and not time.endswith(', '):
  32. time += ', '
  33. time += f'{minute} minute' + ('s' if minute != 1 else '')
  34. if second:
  35. if time and not time.endswith(', '):
  36. time += ', '
  37. time += f'{second} second' + ('s' if second != 1 else '')
  38. ret = ''
  39. if days:
  40. ret = days + ', ' if time else ''
  41. ret += time
  42. return ret
  43. def gen_list(objs,data,*displays,key = None,sort = 0,num_pic = True):
  44. k = displays[sort]
  45. display_data = {obj[k]:obj[data] for obj in objs}
  46. srt_keys = sorted(display_data.keys(),key=key)
  47. display = sorted(
  48. [
  49. [obj[d] for d in displays] for obj in objs
  50. ],
  51. key = lambda row: key(row[sort]) if key else row[sort]
  52. )
  53. if num_pic:
  54. display = [[i] + data for i,data in enumerate(display)]
  55. opts = {
  56. 'spacer':' ',
  57. 'seperator':' ',
  58. 'interactive': True,
  59. 'bottom':'=',
  60. 'l_end':'<',
  61. 'r_end':'>',
  62. }
  63. print2d(display,**opts)
  64. if num_pic:
  65. which = None
  66. while not which:
  67. try:
  68. which = srt_keys[int(input('Which one?: '))]
  69. except ValueError:
  70. which = None
  71. return display_data[which]
  72. else:
  73. ret = None
  74. while not ret:
  75. try:
  76. ret = display_data[input('Which one?: ')]
  77. except KeyError:
  78. pass
  79. return ret
  80. config = '''\
  81. {route} - {end} ({direction})
  82. {nm}, stop {stop_id}
  83. {delta} ({t})\
  84. '''
  85. if __name__ == "__main__":
  86. parser = argparse.ArgumentParser(prog = 'ctabus')
  87. parser.add_argument('arg',nargs = '+',metavar = '(stop-id | cross streets)')
  88. parser.add_argument('-r','--route',default = None)
  89. parser.add_argument('-d','--direction',default = None)
  90. parser.add_argument('-l','--lucky',action='store_true',help = 'picks first result')
  91. args = parser.parse_args()
  92. sys.stderr = open(osp.join(osp.dirname(__file__),'stderr.log'),'w')
  93. args.arg = ' '.join(args.arg)
  94. if not args.arg.isdecimal():
  95. #routes
  96. if not args.route:
  97. data = ctabus.get_routes()['routes']
  98. route = gen_list(data,'rt','rt','rtnm',num_pic = False,key=numb_sort)
  99. else:
  100. route = args.route
  101. data = ctabus.get_directions(route)['directions']
  102. #direction
  103. if not args.direction:
  104. direction = gen_list(data,'dir','dir')
  105. else:
  106. s = Search(args.direction)
  107. direction = sorted((obj['dir'] for obj in data),key = s)[0]
  108. #direction
  109. stops = ctabus.get_stops(route,direction)['stops']
  110. s = StopSearch(args.arg)
  111. if args.lucky:
  112. stop_id = sorted(stops,key=lambda stop: s(stop['stpnm']))[0]['stpid']
  113. else:
  114. stop_id = gen_list(stops,'stpid','stpnm',key = s)
  115. else:
  116. stop_id = args.arg
  117. times = ctabus.get_times(stop_id)['prd']
  118. today = datetime.datetime.today()
  119. for time in sorted(times,key = lambda t: t["prdtm"]):
  120. arrival = date_parse(time['prdtm'])
  121. delta = pprint_delta(arrival-today)
  122. t = arrival.strftime('%H:%M:%S')
  123. route = time['rt']
  124. direction = time['rtdir']
  125. end = time['des']
  126. nm = time['stpnm']
  127. print(
  128. config.format(**globals()),end= '\n'*2
  129. )