Opticon Stockholm is on Tuesday September 10th, hope to see you there!
Opticon Stockholm is on Tuesday September 10th, hope to see you there!
Hi Sandeep,
I had to import products myself as well, but also needed to import other information (like for instance customer information).
Our solution therefore didn't use the .csv import and I never got around to see if this way of importing could be automated.
However, the solution we did use works very well.
We now use an EPiServer job that is scheduled to run and collect data from a non EPiServer database. This data is then imported into the EPiserver Commerce database by using the EPiServer Commerce dto objects.
The job handles all kinds of stuff (productinformation, pricing, customers, organisations) and all works fine.
An example for importing catalogs (categories and entries are imported afterwards):
public static int CreateCatalog(Catalog catalog)
{
CatalogDto catalogDto = CatalogContext.Current.GetCatalogDto(-1, new CatalogResponseGroup(CatalogResponseGroup.ResponseGroup.CatalogInfo));
CatalogDto.CatalogRow newCatalogRow = catalogDto.Catalog.NewCatalogRow();
Mapper.CatalogRowMapper(catalog, newCatalogRow);
catalogDto.Catalog.AddCatalogRow(newCatalogRow);
CatalogContext.Current.SaveCatalog(catalogDto);
return catalogDto.Catalog[0].CatalogId;
}
Hi,
In order to import CSV file, you need to have the mapping file as well. You can take a look at the EPiServer Commerce Webhelp: http://webhelp.episerver.com/Commerce/1.1/EN/user/Default.htm
Navigate to Commerce Manager > Catalog Management > Working with Catalogs > Using CSV Files to Quickly Create Custom Catalogs
You can:
1. Go to Commerce Manager and Catalog CSV Import
2. Upload your CSV file and mapping
3. Save mapping file to your solution.
4. Next time you can use CSV and Mapping file to import
private void ImportCatalogCsvFile(string csvFilePath, string mappingFilePath)
{
Rule rule = Rule.XmlDeserialize(CatalogContext.MetaDataContext, mappingFilePath);
char textQualifier = '\0';
if (!string.IsNullOrEmpty(rule.Attribute["TextQualifier"]))
{
textQualifier = char.Parse(rule.Attribute["TextQualifier"]);
}
string encodingAtt = string.IsNullOrEmpty(rule.Attribute["Encoding"]) ? "Default" : rule.Attribute["Encoding"];
Encoding encoding = Encoding.Default;
if (!string.IsNullOrEmpty(encodingAtt) && encodingAtt.Equals("Default", StringComparison.OrdinalIgnoreCase))
{
encoding = Encoding.GetEncoding(encodingAtt);
}
var sourcePath = HttpContext.Current.Server.MapPath(ManagementHelper.GetImportExportFolderPath("csv/data"));
IIncomingDataParser dataParser = new CsvIncomingDataParser(sourcePath, true, char.Parse(rule.Attribute["Delimiter"]), textQualifier, true, encoding);
DataSet dataSet = dataParser.Parse(Path.GetFileName(csvFilePath), null);
DataTable rawData = dataSet.Tables[0];
int catalogId = 1;
FillResult fillResult = null;
string typeName;
if ((typeName = rule.Attribute["TypeName"]) != null)
{
switch (typeName)
{
case "Category":
{
CatalogContext.MetaDataContext.UseCurrentUICulture = false;
CatalogContext.MetaDataContext.Language = rule.Attribute["Language"];
MappingMetaClass mappingMetaClass = new CategoryMappingMetaClass(CatalogContext.MetaDataContext, rule.ClassName, catalogId);
fillResult = mappingMetaClass.FillData(FillDataMode.All, rawData, rule, -1, DateTime.UtcNow);
CatalogContext.MetaDataContext.UseCurrentUICulture = true;
}
break;
case "Entry":
{
CatalogContext.MetaDataContext.UseCurrentUICulture = false;
CatalogContext.MetaDataContext.Language = rule.Attribute["Language"];
MappingMetaClass mappingMetaClass = new EntryMappingMetaClass(CatalogContext.MetaDataContext, rule.ClassName, catalogId);
fillResult = mappingMetaClass.FillData(FillDataMode.All, rawData, rule, -1, DateTime.UtcNow);
CatalogContext.MetaDataContext.UseCurrentUICulture = true;
}
break;
case "EntryRelation":
{
MappingMetaClass mappingMetaClass = new EntryRelationMappingMetaClass(CatalogContext.MetaDataContext, catalogId);
fillResult = mappingMetaClass.FillData(FillDataMode.All, rawData, rule, -1, DateTime.UtcNow);
}
break;
case "EntryAssociation":
{
MappingMetaClass mappingMetaClass = new EntryAssociationMappingMetaClass(CatalogContext.MetaDataContext, catalogId);
fillResult = mappingMetaClass.FillData(FillDataMode.All, rawData, rule, -1, DateTime.UtcNow);
}
break;
case "Variation":
{
MappingMetaClass mappingMetaClass = new VariationMappingMetaClass(CatalogContext.MetaDataContext, catalogId);
fillResult = mappingMetaClass.FillData(FillDataMode.All, rawData, rule, -1, DateTime.UtcNow);
}
break;
case "SalePrice":
{
MappingMetaClass mappingMetaClass = new PricingMappingMetaClass(CatalogContext.MetaDataContext, catalogId);
fillResult = mappingMetaClass.FillData(FillDataMode.All, rawData, rule, -1, DateTime.UtcNow);
}
break;
}
}
if (fillResult != null)
{
if (fillResult.ErrorRows > 0)
{
Exception[] exceptions = fillResult.Exceptions;
foreach (Exception ex2 in exceptions)
{
string text = ex2.Message;
if (ex2 is MDPImportException)
{
var ex3 = (MDPImportException)ex2;
if (ex3.RowIndex > -1)
{
text = string.Format("Import error. Line {0}: {1}", ex3.RowIndex + 1, text);
}
}
Console.WriteLine(text);
}
}
if (fillResult.Warnings.Length > 0)
{
MDPImportWarning[] warnings = fillResult.Warnings;
foreach (MDPImportWarning warning in warnings)
{
Console.WriteLine(string.Format("Line {0}: {1}", warning.RowIndex + 1, warning.Message));
}
}
Console.WriteLine(string.Format("Succeed: {0} in Total {1}", fillResult.SuccessfulRows, fillResult.TotalRows));
}
}
Hi
I have recently created the necessary csv files to import products into the episerver database. All works fine and I like the csv format for creating the products as compared to writing the whole code to import the products. I need to automate the process. Basically all I need to do is to create a file watcher and as soon a file is dropped in the folder it imports the file into the db. What I wanted to know is that whether there is a way to import the csv files in code using a web service or as API. I need to import all 8 type of csv files provided by episerver. Any help is appreciated.
Thanks
Kind Regards
Sandeep