Die neu in Python, und angesichts der Antwort auf folgende Beitrag schreiben:verschachtelte JSON parsen und zu CSV (Revisited)
Parsing nested JSON and writing it to CSV
Wie definiere ich die Eingabedatei für diesen Code zu arbeiten? Ich verstehe, dass ich die "Ausgabedatei" als den Pfad/den Dateinamen definieren muss, zu dem ich schreibe, aber ich weiß nur nicht, wohin die Eingabedatei gehen soll?
EDIT: Hinzufügen für die Klarheit, dass ich eine JSON-Datei für die Eingabe habe und es in eine CSV-Datei als Ausgabe konvertieren möchte. Ich möchte nur wissen, wie man den Code schreibt, der das Beispiel (von oben) nehmen und eine bestimmte JSON-Datei als Eingabe angeben würde. Der Übersichtlichkeit halber wird der Name der JSON-Datei gleich bleiben, aber der Inhalt wird sich täglich ändern, also muss ich nur wissen, wo ich die open() einfügen soll und wie ich sie im Skript aufrufen soll.
EDIT_2:
inputfile = "/some/file.json"
outputfile = "/some/file.csv"
with open(inputfile, 'r') as inf:
with open(outputfile, 'w') as outf:
writer = None # will be set to a csv.DictWriter later
fp = open(inputfile, 'r')
json_value = fp.read()
data = json.loads(json_value)
for key, item in sorted(data.items(), key=itemgetter(0)):
row = {}
nested_name, nested_items = '', {}
for k, v in item.items():
if not isinstance(v, dict):
row[k] = v
else:
assert not nested_items, 'Only one nested structure is supported'
nested_name, nested_items = k, v
if writer is None:
# build fields for each first key of each nested item first
fields = sorted(row)
# sorted keys of first item in key sorted order
nested_keys = sorted(sorted(nested_items.items(), key=itemgetter(0))[0][1])
fields.extend('__'.join((nested_name, k)) for k in nested_keys)
writer = csv.DictWriter(outf, fields)
writer.writeheader()
for nkey, nitem in sorted(nested_items.items(), key=itemgetter(0)):
row.update(('__'.join((nested_name, k)), v) for k, v in nitem.items())
writer.writerow(row)
Der Fehler, den ich bekommen habe ist ...
for k, v in item.items():
Attribute: 'list' Objekt hat kein Attribut 'Elemente'
Ich glaube, ich kann nicht Lesen Sie die JSON-Datei korrekt ... Python-Newbie-Stressoren.
EDIT_3 (aktualisiert JSON-Struktur): Hier wird ein 'Eintrag' aus der JSON-Datei I (NIST/NVD JSON-Datei) bin mit:
{
"CVE_data_type" : "CVE",
"CVE_data_format" : "MITRE",
"CVE_data_version" : "4.0",
"CVE_data_numberOfCVEs" : "6208",
"CVE_data_timestamp" : "2017-08-14T18:06Z",
"CVE_Items" : [ {
"cve" : {
"CVE_data_meta" : {
"ID" : "CVE-2003-1547"
},
"affects" : {
"vendor" : {
"vendor_data" : [ {
"vendor_name" : "francisco_burzi",
"product" : {
"product_data" : [ {
"product_name" : "php-nuke",
"version" : {
"version_data" : [ {
"version_value" : "6.5"
}, {
"version_value" : "6.5_beta1"
}, {
"version_value" : "6.5_rc3"
}, {
"version_value" : "6.5_rc2"
}, {
"version_value" : "6.5_rc1"
} ]
}
} ]
}
} ]
}
},
"problemtype" : {
"problemtype_data" : [ {
"description" : [ {
"lang" : "en",
"value" : "CWE-79"
} ]
} ]
},
"references" : {
"reference_data" : [ {
"url" : "http://secunia.com/advisories/8478"
}, {
"url" : "http://securityreason.com/securityalert/3718"
}, {
"url" : "http://www.securityfocus.com/archive/1/archive/1/316925/30/25250/threaded"
}, {
"url" : "http://www.securityfocus.com/archive/1/archive/1/317230/30/25220/threaded"
}, {
"url" : "http://www.securityfocus.com/bid/7248"
}, {
"url" : "https://exchange.xforce.ibmcloud.com/vulnerabilities/11675"
} ]
},
"description" : {
"description_data" : [ {
"lang" : "en",
"value" : "Cross-site scripting (XSS) vulnerability in block-Forums.php in the Splatt Forum module for PHP-Nuke 6.x allows remote attackers to inject arbitrary web script or HTML via the subject parameter."
} ]
}
},
"configurations" : {
"CVE_data_version" : "4.0",
"nodes" : [ {
"operator" : "OR",
"cpe" : [ {
"vulnerable" : true,
"cpeMatchString" : "cpe:/a:francisco_burzi:php-nuke:6.5",
"cpe23Uri" : "cpe:2.3:a:francisco_burzi:php-nuke:6.5:*:*:*:*:*:*:*"
}, {
"vulnerable" : true,
"cpeMatchString" : "cpe:/a:francisco_burzi:php-nuke:6.5_beta1",
"cpe23Uri" : "cpe:2.3:a:francisco_burzi:php-nuke:6.5_beta1:*:*:*:*:*:*:*"
}, {
"vulnerable" : true,
"cpeMatchString" : "cpe:/a:francisco_burzi:php-nuke:6.5_rc1",
"cpe23Uri" : "cpe:2.3:a:francisco_burzi:php-nuke:6.5_rc1:*:*:*:*:*:*:*"
}, {
"vulnerable" : true,
"cpeMatchString" : "cpe:/a:francisco_burzi:php-nuke:6.5_rc2",
"cpe23Uri" : "cpe:2.3:a:francisco_burzi:php-nuke:6.5_rc2:*:*:*:*:*:*:*"
}, {
"vulnerable" : true,
"cpeMatchString" : "cpe:/a:francisco_burzi:php-nuke:6.5_rc3",
"cpe23Uri" : "cpe:2.3:a:francisco_burzi:php-nuke:6.5_rc3:*:*:*:*:*:*:*"
} ]
} ]
},
"impact" : {
"baseMetricV2" : {
"cvssV2" : {
"vectorString" : "(AV:N/AC:M/Au:N/C:N/I:P/A:N)",
"accessVector" : "NETWORK",
"accessComplexity" : "MEDIUM",
"authentication" : "NONE",
"confidentialityImpact" : "NONE",
"integrityImpact" : "PARTIAL",
"availabilityImpact" : "NONE",
"baseScore" : 4.3
},
"severity" : "MEDIUM",
"exploitabilityScore" : 8.6,
"impactScore" : 2.9,
"obtainAllPrivilege" : false,
"obtainUserPrivilege" : false,
"obtainOtherPrivilege" : false,
"userInteractionRequired" : true
}
},
"publishedDate" : "2003-12-31T05:00Z",
"lastModifiedDate" : "2017-08-08T01:29Z"
}]
}
ich den Schlüssel möchte die Header sein (wie lastModifiedDate, cpe23Uri, etc) für die CSV-Datei. Ich kann Leerraum herausfiltern und nur die Spalten auswählen, die ich möchte, sobald ich die Header und Daten in der CSV-Datei habe.
@MartjinPieters ... Sie die verknüpfte Frage beantwortet ... Sie diese auch beantworten können? : p –
Bei dieser Frage wird davon ausgegangen, dass Sie die Daten bereits in einer Liste haben. Sie können die Daten nach Belieben abrufen. Es muss nicht aus einer Eingabedatei stammen, es kann aus Berechnungen stammen, die Sie ausführen. – Barmar
Wenn Sie es aus einer anderen Datei abrufen möchten, schreiben Sie einfach Code, um diese Datei zu öffnen und sie auf die jeweils geeignete Weise zu parsen. – Barmar