Elimde barkod numarası, ürün adı ve fiyat bilgilerini içeren bir Excel dosyası vardı ve bu verileri belirli bir YAML formatına dönüştürmek istedim. Ancak, verilerde gereksiz boşluklar ve fiyat formatında küçük değişiklikler yapmam gerekiyordu. Python kullanarak bu işlemi otomatikleştirdim ve aşağıda kullandığım çözümü paylaşıyorum.
YAML formatı örneği:
- Name: Test Ürünü
GroupCode: Market
Barcode: "12345"
Portions:
- Name: Normal
Price: 6,5
İstediğim gereksinimler:
- Ürün isimleri ve barkodlarda başta ve sonda yer alan gereksiz boşlukların silinmesi.
- Fiyatın 6.5 yerine 6,5 olacak şekilde nokta yerine virgülle yazılması.
- Excel’deki her satırın yukarıdaki YAML formatına dönüştürülmesi.
Çözüm Kodu:
import pandas as pd
import yaml
# Excel dosyasını oku
excel_path = "urunler.xlsx" # Dosya yolunu buraya yazın
df = pd.read_excel(excel_path)
# Her satırı YAML formatına dönüştür
yaml_data = []
for index, row in df.iterrows():
product = {
"Name": row["Ürün Adı"].strip(), # Boşlukları kaldır
"GroupCode": "Market",
"Barcode": str(row["Barkod Numarası"]).strip(), # Boşlukları kaldır
"Portions": [
{
"Name": "Normal",
"Price": str(row["Fiyat"]).replace('.', ',') # Noktayı virgülle değiştir
}
]
}
yaml_data.append(product)
# YAML çıktısını dosyaya yaz
with open("urunler.yaml", "w", encoding="utf-8") as yaml_file:
yaml.dump(yaml_data, yaml_file, allow_unicode=True, sort_keys=False)
print("YAML dosyası başarıyla oluşturuldu!")
Sonuç:
Bu kod sayesinde Excel’deki her satır otomatik olarak istediğim YAML formatına dönüştürüldü. Gereksiz boşluklar temizlendi ve fiyatlar virgüllü formata uygun hale getirildi. Aynı problemle karşılaşanlar için faydalı olacağını umuyorum.
Sorusu veya önerisi olan varsa memnuniyetle yanıtlarım!