Converti Classe Definita Personalmente in Excel

Converti Classe Personalizzata in Excel

A volte, abbiamo una collezione di classi, e se vogliamo importare le informazioni della classe in un file Excel, una soluzione comoda è usare il meccanismo di riflessione di Python per includere sia i dati della classe sia i nomi delle sue variabili membro, senza dover conoscere in anticipo i metadati specifici della classe. Ecco un esempio di codice che dimostra come importare i dati da una lista di classi definite dall’utente in un file Excel usando Aspose.Cells per Python via .NET: Il file ImportCustomObject.py definisce le informazioni della classe da importare e utilizza il meccanismo di riflessione di Python per includere sia i dati della classe sia i nomi delle variabili membro in specifici intervalli di celle.

from datetime import date, datetime
import aspose.cells as ac
class MyClass:
def __init__(self, Name, Age, Is_Student, Date, DateTime, Height):
self.Name = Name
self.Age = Age
self.Is_Student = Is_Student
self.Date = Date
self.DateTime = DateTime
self.Height = Height
def import_custom_object(people, cells, row, column, import_options):
# If a header needs to be displayed, write the header (attribute names)
if import_options.is_field_name_shown:
header = vars(people[0]).keys()
for col_index, attr_name in enumerate(header):
cells.get(row, column + col_index).put_value(attr_name)
row += 1
# Write the attribute values of the object
for obj in people:
for col_index, (attr_name, attr_value) in enumerate(vars(obj).items()):
cell = cells.get(row, column + col_index)
if isinstance(attr_value, (int, float, str, bool)):
cell.put_value(attr_value)
elif isinstance(attr_value, (date, datetime)):
cell.put_value(attr_value)
style = cell.get_style()
if isinstance(attr_value, datetime):
style.custom = "yyyy-MM-dd HH:mm:ss"
elif isinstance(attr_value, date):
style.number = 14 # Excel Date Format
cell.set_style(style)
else:
cell.put_value(str(attr_value))
row += 1

Il file TestImportCustomObject.py illustra un caso d’uso semplice. Gli utenti possono fare riferimento a questo esempio o apportare leggere modifiche per importare i propri dati.

from datetime import date, datetime
import aspose.cells as ac
from ImportCustomObject import MyClass, import_custom_object
people = [
MyClass("Bob", 30, True, date(2024, 3, 9), datetime.now(), 112.0),
MyClass("Lucy", 25, False, date(2024, 3, 10), datetime.now(), 111.1),
MyClass("Tom", 45, True, date(2024, 3, 11), datetime.now(), 110.8),
]
workbook = ac.Workbook()
worksheet = workbook.worksheets[0]
cells = worksheet.cells
import_options = ac.ImportTableOptions()
# Display the table header or not
import_options.is_field_name_shown = True
start_row = 4
start_column = 1
import_custom_object(people, cells, start_row, start_column, import_options)
workbook.save("import_custom_object.xlsx")