A python wrapper for Indian Railways Enquiry API!
- Get trains between stations
- Get seat availability
- Get train fare
- Get train schedule
- Get train live running status
- Get PNR status
...and much more!
Note: This is not an official package and using it for commercial purposes is not recommended.
To install pyinrail, simply,
$ pip install pyinrail
You will also need to install tesseract-ocr. Find instructions to install tesseract-ocr here.
- Importing pyinrail
from pyinrail import pyinrail
- Create RailwayEnquiry object
enq = pyinrail.RailwayEnquiry(src='new delhi', dest='ahmedabad', date='12-05-2018')
- Get trains between stations
df = enq.get_trains_between_stations(as_df=True)
print(df)
trainName trainNumber fromStnCode toStnCode departureTime arrivalTime duration distance avlClasses
0 ADI SJ RAJDHANI 12958 NDLS ADI 19:55 09:40 13:45 935 [1A, 2A, 3A]
1 GUJRAT S KRANTI 12918 NZM ADI 13:55 06:10 16:15 1085 [2A, 3A, SL]
2 ASHRAM EXPRESS 12916 DLI ADI 15:20 07:40 16:20 934 [1A, 2A, 3A, SL]
3 ALA HAZRAT EXP 14311 DLI ADI 11:45 06:15 18:30 933 [2A, 3A, SL]
4 YOGA EXPRESS 19032 DSA ADI 21:26 17:10 19:44 963 [1A, 2A, 3A, SL]
5 DEE BDTS G RATH 12215 DEE ADI 09:20 01:10 15:50 951 [3A]
- Get seat availability
df = enq.get_seat_availability(12958, classc='2A', as_df=True)
print(df)
availablityDate availablityStatus availablityType currentBkgFlag reason reasonType waitListType
0 12-5-2018 TRAIN DEPARTED 8224 Y W 8224
1 13-5-2018 GNWL68/WL24 8224 N S 9
2 14-5-2018 GNWL41/WL8 8224 N S 9
3 15-5-2018 GNWL25/WL6 8224 N S 9
4 16-5-2018 GNWL33/WL14 8224 N S 9
5 17-5-2018 GNWL20/WL9 8224 N S 9
- Get train schedule
df = enq.get_train_schedule(12958, as_df=True)
print(df)
stationCode stationName departureTime arrivalTime routeNumber haltTime distance dayCount stnSerialNumber
0 NDLS NEW DELHI 19:55 -- 1 -- 0 1 1
1 DEC DELHI CANTT 20:25 20:23 1 02:00 16 1 2
2 GGN GURGAON 20:43 20:41 1 02:00 32 1 3
3 JP JAIPUR 00:30 00:20 1 10:00 309 2 4
4 AII AJMER JN 02:29 02:25 1 04:00 443 2 5
5 FA FALNA 04:53 04:52 1 01:00 650 2 6
6 ABR ABU ROAD 06:05 06:01 1 04:00 748 2 7
7 PNU PALANPUR JN 07:12 07:10 1 02:00 801 2 8
8 MSH MAHESANA JN 08:05 08:03 1 02:00 866 2 9
9 SBIB SABARMATI BG 09:02 09:00 1 02:00 929 2 10
10 ADI AHMEDABAD JN -- 09:40 1 -- 935 2 11
- Get train fare
fare_data = enq.get_train_fare(12958, classc='2A')
print(fare_data)
{'baseFare': 1841,
'cateringCharge': 225,
'dynamicFare': 921,
'fuelAmount': 0.0,
'goodsServiceTax': 143.0,
'otherCharge': 0,
'reservationCharge': 50,
'superfastCharge': 45,
'tatkalFare': 0,
'totalCollectibleAmount': 3225.0,
'totalConcession': 0,
'totalFare': 3225,
'travelInsuranceCharge': 0.0,
'travelInsuranceServiceTax': 0.0,
'wpServiceCharge': 0.0,
'wpServiceTax': 0.0}
- Get train's live running status
train_detail, instances, detailed_instances = enq.get_train_status(12958, as_df=True)
print(train_detail)
print(instances)
print(detailed_instances[0])
{'dayCnt': '1',
'from': 'NDLS',
'runsOn': '1111111',
'schArrTime': '09:40',
'schDepTime': '19:55',
'to': 'ADI',
'trainName': 'ADI SJ RAJDHANI',
'trainNo': '12958'}
startDate departed curStn terminated lastUpdated totalLateMins
0 12 May 2018 True RE False 12 May 2018 21:43 6
1 11 May 2018 True ADI True 12 May 2018 9:27 -14
stnCode arr schArrTime actArr delayArr dep schDepTime actDep delayDep dayCnt schDayCnt distance
0 NDLS False 00:00 00:00 0 True 19:55 19:55 0 0 0 0
1 DEC True 20:23 20:27 4 True 20:25 20:29 4 0 0 15
2 GGN True 20:41 20:47 6 True 20:43 20:49 6 0 0 32
3 RE True 21:30 21:41 11 True 21:30 21:41 11 0 0 83
4 JP False 00:20 00:20 0 False 00:30 00:30 0 1 1 308
5 AII False 02:25 02:25 0 False 02:29 02:29 0 1 1 442
6 FA False 04:52 04:52 0 False 04:53 04:53 0 1 1 649
7 ABR False 06:01 06:01 0 False 06:05 06:05 0 1 1 747
8 PNU False 07:10 07:10 0 False 07:12 07:12 0 1 1 800
9 MSH False 08:03 08:03 0 False 08:05 08:05 0 1 1 865
10 SBIB False 09:00 09:00 0 False 09:02 09:02 0 1 1 927
11 ADI False 09:40 09:40 0 False 00:00 00:00 0 1 1 934
- A command line client
- A GUI interface
-
Clone the repository
$ git clone http://github.com/nikhilkumarsingh/pyinrail
-
Install dependencies
$ pip install -r requirements.txt
-
To test local version of pyinrail:
$ pip install -U .
OR :
$ pip install -e <project dir.> .