-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #767 from ScrapeGraphAI/fix-export-function
- Loading branch information
Showing
1 changed file
with
57 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
""" | ||
data_export module | ||
This module provides functions to export data to various file formats. | ||
""" | ||
import json | ||
import csv | ||
import xml.etree.ElementTree as ET | ||
from typing import List, Dict, Any | ||
|
||
def export_to_json(data: List[Dict[str, Any]], filename: str) -> None: | ||
""" | ||
Export data to a JSON file. | ||
:param data: List of dictionaries containing the data to export | ||
:param filename: Name of the file to save the JSON data | ||
""" | ||
with open(filename, 'w', encoding='utf-8') as f: | ||
json.dump(data, f, ensure_ascii=False, indent=4) | ||
print(f"Data exported to {filename}") | ||
|
||
def export_to_csv(data: List[Dict[str, Any]], filename: str) -> None: | ||
""" | ||
Export data to a CSV file. | ||
:param data: List of dictionaries containing the data to export | ||
:param filename: Name of the file to save the CSV data | ||
""" | ||
if not data: | ||
print("No data to export") | ||
return | ||
|
||
keys = data[0].keys() | ||
with open(filename, 'w', newline='', encoding='utf-8') as f: | ||
writer = csv.DictWriter(f, fieldnames=keys) | ||
writer.writeheader() | ||
writer.writerows(data) | ||
print(f"Data exported to {filename}") | ||
|
||
def export_to_xml(data: List[Dict[str, Any]], filename: str, root_element: str = "data") -> None: | ||
""" | ||
Export data to an XML file. | ||
:param data: List of dictionaries containing the data to export | ||
:param filename: Name of the file to save the XML data | ||
:param root_element: Name of the root element in the XML structure | ||
""" | ||
root = ET.Element(root_element) | ||
for item in data: | ||
element = ET.SubElement(root, "item") | ||
for key, value in item.items(): | ||
sub_element = ET.SubElement(element, key) | ||
sub_element.text = str(value) | ||
|
||
tree = ET.ElementTree(root) | ||
tree.write(filename, encoding='utf-8', xml_declaration=True) | ||
print(f"Data exported to {filename}") | ||
|