mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 10:00:23 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			126 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			126 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import sys
 | |
| from datetime import datetime
 | |
| mycall="K1JT"
 | |
| mygrid="FN20"
 | |
| 
 | |
| # Keyed with hiscall:
 | |
| Freq={}
 | |
| T0={}
 | |
| RcvdExch={}
 | |
| Grid={}
 | |
| 
 | |
| # Keyed with hiscall_band:
 | |
| Staged={}
 | |
| TimeLogged={}
 | |
| QSOinProgress={}
 | |
| # QSOinProgress bit values:
 | |
| #  1 He called me
 | |
| #  2 I called him
 | |
| #  4 Received his exchange
 | |
| #  8 Received his Roger
 | |
| # 16 Sent Roger
 | |
| # 32 Staged for logging
 | |
| 
 | |
| def isGrid(g):
 | |
|     """Return True if g is a valid grid4 and not RR73"""
 | |
|     if len(g)!=4 or g=="RR73": return False
 | |
|     if ord(g[0:1])<ord('A') or ord(g[0:1])>ord('R'): return False
 | |
|     if ord(g[1:2])<ord('A') or ord(g[1:2])>ord('R'): return False
 | |
|     if ord(g[2:3])<ord('0') or ord(g[2:3])>ord('9'): return False
 | |
|     if ord(g[3:4])<ord('0') or ord(g[3:4])>ord('9'): return False
 | |
|     return True
 | |
| 
 | |
| if len(sys.argv)!=4:
 | |
|     print "Usage:   python all2cab.py <mycall> <mygrid> <infile>"
 | |
|     print "Example: python all2cab.py K1JT FN20 all_wwdigi_2019.txt"
 | |
|     exit()
 | |
| 
 | |
| f=open(sys.argv[3],mode='r')
 | |
| ss=f.readlines()
 | |
| f.close
 | |
| dt0=datetime.strptime(ss[0][0:13],"%y%m%d_%H%M%S")
 | |
| iz=len(ss)
 | |
| nqso=0
 | |
| hiscall_band=""
 | |
| 
 | |
| for i in range(iz):
 | |
|     s=ss[i][0:80].strip()
 | |
|     dt=datetime.strptime(s[0:13],"%y%m%d_%H%M%S")
 | |
|     tx=" Tx " in s              #True if this is my transmission
 | |
|     w=s.split()
 | |
|     if len(w)<10: continue
 | |
|     if w[7]=="CQ":
 | |
|         cq=True
 | |
|         if w[8].isalpha():
 | |
|             s=s.replace(" CQ "," CQ_")
 | |
|             w=s.split()
 | |
|     if len(w)<10: continue
 | |
|     c1=w[7]
 | |
|     c2=w[8]
 | |
|     c3=w[9]
 | |
|     roger = c3=="R"
 | |
|     if roger: c3=w[10]
 | |
|     cq = (c1=="CQ" or c1[0:3]=="CQ_")
 | |
|     if cq:
 | |
|         Grid[c2]=c3
 | |
| 
 | |
|     hiscall=""
 | |
|     if tx and not cq:
 | |
|         hiscall=c1
 | |
|     if c1==mycall:
 | |
|         freq=int(1000.0*float(s[13:23])) + int((int(s[42:47]))/1000)
 | |
|         hiscall=c2
 | |
|         Freq[hiscall]=freq
 | |
|         MHz="%3d" % int(float(s[13:23]))
 | |
|         hiscall_band=hiscall+MHz
 | |
|         n=QSOinProgress.get(hiscall_band,0)
 | |
|         n = n | 1                                 #He called me
 | |
|         if roger or c3=="RR73" or c3=="RRR" or c3=="73":
 | |
|             n = n | 8                             # Rcvd Roger
 | |
|         if isGrid(c3):
 | |
|             hisgrid=c3
 | |
|             RcvdExch[hiscall]=hisgrid
 | |
|             n = n | 4                             #Received his exchange
 | |
|         else:
 | |
|             g=Grid.get(hiscall,"")
 | |
|             if isGrid(g):
 | |
|                 RcvdExch[hiscall]=g
 | |
|                 n = n | 4                         #Received his exchange
 | |
|         QSOinProgress[hiscall_band]=n
 | |
|         
 | |
|     if len(hiscall)>=3:
 | |
|         MHz="%3d" % int(float(s[13:23]))
 | |
|         hiscall_band=hiscall+MHz
 | |
|         if tx:
 | |
|             n=QSOinProgress.get(hiscall_band,0)
 | |
|             n = n | 2                             #I called him
 | |
|             if roger or c3=="RR73" or c3=="RRR" or c3=="73":
 | |
|                 n = n | 4 | 16                    #Rcvd Exch, Sent Roger
 | |
|             if c3=="RR73" or c3=="RRR" or c3=="73":
 | |
|                 n = n | 8                         #Rcvd Exch, Sent Roger
 | |
|             QSOinProgress[hiscall_band]=n
 | |
|         T0[hiscall]=dt
 | |
| 
 | |
|     if len(hiscall_band)<5 or len(hiscall)<3: continue
 | |
|     
 | |
|     if QSOinProgress.get(hiscall_band,0)>=31:
 | |
|         n=QSOinProgress.get(hiscall_band,0)
 | |
|         n = n | 32
 | |
|         QSOinProgress[hiscall_band]=n
 | |
|         t=str(T0[hiscall])[0:16]
 | |
|         t=t[0:13] + t[14:16]
 | |
|         buf="QSO: %5d DG %s %-10s    %s       %-10s    %s" % (Freq[hiscall],t,\
 | |
|                 mycall,mygrid,hiscall,RcvdExch.get(hiscall,"    "))
 | |
|         MHz="%3d" % int(float(s[13:23]))
 | |
|         hiscall_band=hiscall+MHz
 | |
|         t=Staged.get(hiscall_band,"")
 | |
|         time_diff=-1
 | |
|         if TimeLogged.get(hiscall_band,0)!=0:
 | |
|             time_diff=(T0[hiscall] - TimeLogged[hiscall_band]).total_seconds()
 | |
|         if time_diff == -1 or time_diff > 180:    #Log only once within 3 min
 | |
|             Staged[hiscall_band]=buf              #Staged for logging
 | |
|             nqso=nqso+1
 | |
|             TimeLogged[hiscall_band]=T0[hiscall]
 | |
|             print buf                             #For now, log anything staged
 | |
|             del QSOinProgress[hiscall_band]
 |