Ich habe einen Datenrahmen wie diesen:
ORDER_NO 2401 2504 2600
2020020 2019-12-04 2019-12-10 2019-12-12
2020024 2019-12-25 NaN 2019-12-20
2020034 NaN NaN 2019-12-20
2020020 2019-12-12 2019-12-15 2019-12-18
Ich erstelle XML aus dem obigen Datenrahmen. Ich möchte den Nullwert entfernen, der in das XML eingefügt wird. Mein Code sollte diesen bestimmten Spalten- und Zeilenwert aus XML löschen.
Mein Code
header = """<ORD>{}</ORD>"""
body ="""
<osi:ORDSTSINF types:STSCDE="{}">
<DTM>{}</DTM>"""
cols = df.columns
for row in df.itertuples():
with open(f'{row[1]}.xml', 'w') as f:
f.write(header.format(row[1]))
for c, r in zip(row[2:], cols[1:]):
f.write(body.format(r, c))
Aktuelle Ausgabe für Datensatz 2
<ORD>2020024</ORD>
<osi:ORDSTSINF types:STSCDE="2401">
<DTM>2019-12-25</DTM>
<osi:ORDSTSINF types:STSCDE="2504">
<DTM>NaN</DTM>
<osi:ORDSTSINF types:STSCDE="2600">
<DTM>2019-12-20</DTM>
Erwartete Ausgabe für Datensatz 2
<ORD>2020024</ORD>
<osi:ORDSTSINF types:STSCDE="2401">
<DTM>2019-12-25</DTM>
<osi:ORDSTSINF types:STSCDE="2600">
<DTM>2019-12-20</DTM>
Wie geht das in Python?
footer = """<END>123</END>""
) hinzugefügt, aber die Ausgabe erfolgt in derselben Zeile<DTM>2020-03-29</DTM><END>123</END>
anstelle einer neuen Zeile.f.write
, wird nicht davon ausgegangen, dass Sie ein'\n'
für Sie setzen. Sie haben diese aus Ihrerbody
Zeichenfolge. Geben Sie Ihre Fußzeile mitfooter = """\n<END>123</END>"""