Compare commits

2 Commits

Author SHA1 Message Date
512cb17264 Fix formatting 2021-09-08 20:39:46 +02:00
fb6ca1da51 Remove missing id lines 2021-09-08 18:56:04 +02:00
3 changed files with 42 additions and 17 deletions

View File

@@ -11,6 +11,7 @@ import xml.etree.ElementTree as ET
import csv import csv
import datetime import datetime
import os import os
import xmlformatter
# ---------------------------------------------------------------------------- # # ---------------------------------------------------------------------------- #
@@ -70,11 +71,11 @@ def getXmlData(data):
def checkData(xmlData): def checkData(xmlData):
print() print()
missingData = False missingData = []
for mérő in xmlData: for i, mérő in enumerate(xmlData):
for adat in mérő: for adat in mérő:
if len(mérő[adat]) == 0: if len(mérő[adat]) == 0 or mérő[adat] == "diktalos":
missingData = True missingData.append(i)
print(f'Adat hiányzik: "{adat}" a következő sorból:') print(f'Adat hiányzik: "{adat}" a következő sorból:')
print(mérő) print(mérő)
return missingData return missingData
@@ -147,16 +148,22 @@ for i, table in enumerate(csvArrs):
xmlReqData = [] xmlReqData = []
for i, table in enumerate(reqData): for i, table in enumerate(reqData):
print(f'Fájl ellenőrzése: {csvFileNames[i]}') print(f'Fájl ellenőrzése: {csvFileNames[i]}')
# unwrap data
currXmlData = getXmlData(table) currXmlData = getXmlData(table)
if not checkData(currXmlData):
# check for missing data
wrongLines = checkData(currXmlData)
if len(wrongLines) == 0:
print('Fájl hibátlan') print('Fájl hibátlan')
else:
# remove bad lines
print(wrongLines)
for ele in sorted(wrongLines, reverse=True):
del currXmlData[ele]
print() print()
xmlReqData.append(currXmlData) xmlReqData.append(currXmlData)
# print(xmlReqData)
# for i in xmlReqData:
# print(i)
# ------------------------------- Merge arrays ------------------------------- # # ------------------------------- Merge arrays ------------------------------- #
@@ -182,24 +189,36 @@ while fileNameNotFound:
if not os.path.exists(fileName): if not os.path.exists(fileName):
fileNameNotFound = False fileNameNotFound = False
print(f'Fájl mentése ide: {fileName}') print(f'Fájl mentése ide: {fileName}')
print() print()
# --------------------------------- Write xml -------------------------------- # # --------------------------------- Write xml -------------------------------- #
data = ET.Element('Leolvasasok') data = ET.Element('Leolvasasok')
data.tail = '\r\n'
for mérő in allXmlData: for mérő in allXmlData:
currSub = ET.SubElement(data, 'Leolvasas') currSub = ET.SubElement(data, 'Leolvasas')
currSub.tail = '\r\n'
for adat in mérő: for adat in mérő:
a = ET.SubElement(currSub, adat) a = ET.SubElement(currSub, adat)
a.text = mérő[adat] a.text = mérő[adat]
a.tail = '\r\n'
print(ET.dump(data)) xmlString = ET.tostring(data, encoding="utf-8", xml_declaration=True)
print()
tree = ET.ElementTree(data) # -------------------------------- Format xml -------------------------------- #
tree.write(fileName, encoding="utf-8", xml_declaration=True)
formatter = xmlformatter.Formatter(indent="2", indent_char=" ")
formattedXml = formatter.format_string(xmlString)
# print(formattedXml)
# ----------------------------- Fix line endings ----------------------------- #
WINDOWS_LINE_ENDING = b'\r\n'
UNIX_LINE_ENDING = b'\n'
formattedXml = formattedXml.replace(UNIX_LINE_ENDING, WINDOWS_LINE_ENDING)
# --------------------------------- Save file -------------------------------- #
f = open(fileName, "xb")
f.write(formattedXml)
f.close

View File

@@ -27,3 +27,8 @@ A file nevében ne legyen ékezetes karakter.
Egy sor sem lehet 50 karakternél hosszabb! Egy sor sem lehet 50 karakternél hosszabb!
## Telepítés
```shell
pip install -r requirements.txt
```

1
requirements.txt Normal file
View File

@@ -0,0 +1 @@
xmlformatter