Я хотел бы конвертировать конкретный файл ASCII в CSV.
Этот файл имеет собственную спецификацию, и я публикую ниже соответствующие фрагменты.
строка A начинается с кода 66TP:
66TP 1003 54.437269600149717.012388003107655.5139691177756 :10.008677993245250.01231534739191
строка B начинается с C6NM:
C6NM0821.565823793411260.900167346000671.2812114953994820.81007696688170033 1679475490.0000000001679475527.0000000001
Как вы видите выше, отдельные значения не разделены, но их дифференциация
по положению и длине в строке.
спецификация линии A:
1 Position Length Data format Description of field
2 1 2 Type code Record type code = 66
3 3 2 Derivation Derivation code
4 5 16 Name Point name
5 21 16 Latitude Latitude
6 37 16 Longitude Longitude
7 53 16 Distance WGS84 ellipsoidal height at APC
8 69 16 Text 16 Feature code
9 85 1 GPS Method Measurement method
10 86 1 Classification Classification of the point
11 87 16 Distance Horizontal precision
12 103 16 Distance Vertical precision
спецификация линии B:
1 Position Length Data format Description of field
2 1 2 Type code Record type code = C6
3 3 2 Derivation Derivation code
4 5 2 Integer 2 Minimum number of satellites
5 7 1 Boolean Relative DOPs
6 8 16 Scalar PDOP (maximum)
7 24 16 Scalar HDOP (maximum)
8 40 16 Scalar VDOP (maximum)
9 56 16 Scalar RMS
10 72 4 Integer 4 Number of GPS positions used
11 76 16 Distance Horizontal standard deviation
12 92 16 Distance Vertical standard deviation
13 108 4 Integer 4 Start GPS week
14 112 16 Scalar Start GPS time in seconds to 3dp
15 128 4 Integer 4 End GPS Week
16 132 16 Scalar End GPS time in seconds to 3dp
17 148 1 Monitor Status
Мой желаемый результат - объединить обе строки и будет выглядеть так:
1003,54.4372696001497,17.0123880031076,55.5139691177756,0.009,0.012,8,1.6,0.9,1.28,20.8,033,1679,475490.0,1679,475527.0
и вот входной файл, где я пометил отдельные значения в квадратных скобках:
66TP [1003] [54.4372696001497][17.0123880031076][55.5139691177756] :1[0.00867799324525][0.01231534739191]
C6NM[082][1.56582379341126][0.90016734600067][1.28121149539948][20.81007696688170][033] [1679][475490.000000000][1679][475527.0000000001]
Извините за довольно длинный пост, но я понятия не имею, как я могу описать это в более краткой форме.
Я начинающий программист-любитель, и я хотел бы попросить вас дать нам подсказку, которая позволила бы мне начать
обработка данных такого типа.