Skip to content

Commit

Permalink
Merge pull request #767 from ScrapeGraphAI/fix-export-function
Browse files Browse the repository at this point in the history
  • Loading branch information
VinciGit00 authored Oct 25, 2024
2 parents fd57cc7 + 6179ab9 commit f9c1432
Showing 1 changed file with 57 additions and 0 deletions.
57 changes: 57 additions & 0 deletions scrapegraphai/utils/data_export.py
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}")

0 comments on commit f9c1432

Please sign in to comment.