>gh ddlZddlmcmZddlZddlddlmZdZ dZ dZ dZ ddd d d d d dddddd Z dZdZdZy)N)*) stationInfocH|j|}|dk(r td|S)NzCould not find)find ValueError)sfindexs ./home/thomas/Documents/TrainMap/getLineData.pyfinder s' FF1IE {)** MctdD]}|t|ddzd} |t|ddzd}|ddk7rnt|dt|djdd}td D]}|t|ddzd} |t|ddzd}|dd d k(rn|d t|ddd} |t|ddzd}|ddk7rn|dt|d}tdD]}|t|ddzd}||||fS) Ntd>r<,.zz z z z -  ) urllib3 PoolManagerurlopenstrdatarr splitappendrr!)number user_agenthttpurlr irtsubLines dateStringdate fromToString fromStringtoStringstationsrr rs r lineInfor@&s'J   r* 5D ,,uMfXV WC CHH A A 1X eAacdGG$Q&' ( 57 AH  %*%a'()A0E!K01J##H-D%+&r)*+A2eAk23L$0$6$6u$= !Z OOZ//=h>N>NxX[>\]ab c   %!A#$  " #$A %!A#$  " #$AH$*1~ QtD OOT$t, -$"#sBDD#&E??Fc d}tj|}tj|}tj|}tj|}d|ztjtjtj||z dz dztj |tj |ztj||z dz dzzzz} | S)Ngn#@r)mathradiansasinsqrtsincos) latd1longd1latd2longd2Rlat1long1lat2long2ds r dist_coordsrRLsA << D LL E << D LL E !DIIdii$t)Q 7 :488D>$((SW.;XY]YaYachincnpqbqYrtuYu;u uv wwA Irrrrr'rr)rr$ ) janfebmrtaprmeijunjulaugsepoktnovdeccz|j}t|ddt|ddt|dzzzzS)Nrr r)r;intmonthDic)itemr;s r dateKeyrhXs= 99D tAw<HT!W-3tAw<?@ @Arc t|}tj|}|jdd}g}d}d}d}d} d} |D]} | j dd} | j dd} | sx|t t |t |t | t | z }| t|kr5||| dk\r*| dz } |jt | t | f| | }}d} |jt |t |ft|dgdg}t||D]~\}}t|d\}}|gk(rtd|d|D](}|jt|d|d|d|*|D] }|jt|d|"|jt |S) NrrTFred)0rV1800rz It did not go well with station )key)r@ETparsegetrootitemsrRrlenr2LineziprprintStation RemoveStationsortrh)r lineNumr?treetrksegstation_pointsrprev_lat_pointprev_lon_pointfirstr7trkpt lat_point lon_pointrqstation station_pointopeningsclosingsopeningclosings r getItemListr\s H 88D>D \\^A q !FN DNN E AKKM!$Q' KKM!$Q'  +eN3E.4I%PYJZ[`aj[kl lDX4!Q#71%%uY'7i8H&IJ)2950~1FGH $u/ 0 1E$'x#?)'!*5( R< 4WQZLA BG LLM!,<]1=MgV W G LLwqz': ; $@ JJ7J Mrct||}t|dd}|D]$}|j|jdz&|j y)Nrqw )ropenwriter>close)r ryrqr rgs r lineInFilersK W %E y s#A  $%GGIr)r,xml.etree.ElementTreeetree ElementTreernrBrggetStationDatarr r!r@rRrfrhrrrr rsa"" & 4#$L!!!!!!!RSZ[bdkm nB$Lr