说明:
1、nopCommerce程序从4.0到4.40中都是通过EPPlus中间件来实现nopCommerce程序与Excel之间数据的导入导出操作;而从4.5x以后的版本nopCommerce开发者,则是通过ClosedXML中间件来实现nopCommerce程序与Excel之间数据的导入导出操作。
2、从版本的迭代的角度来讲本人认为EPPlus中间件比ClosedXML中间件更为有优势;总体上EPPlus在速度和内存上都最佳,感觉ClosedXML在API调用上方便一些,文档写全面一些(这句评价来源于网络),至于最终开发者在进行二次开发时,怎么选择这两个中间来协助完成程序与Excel之间数据的导入导出操作,取决于开发者对二者的综合理解的程度。
3、说实话本人对这些两个中间件基本没有了解,而nopCommerce程序对这两个中间件的应用又相当的机巧、深奥和艰深,如果想要深入理解nopCommerce程序与Excel之间数据的导入导出操作的实现,本人建议如果有时间在网上找一些简示例程序先对这两个中间有一定的理解基础,才能在学习曲线不是那么陡峭的情况下更好的来理解nopCommerce程序与Excel之间数据的导入导出操作的实现。
117 Extensions、PropertyByName<T>、PropertyManager<T>、ExportedAttributeType、ImportProductMetadata、ExportProductAttribute、ExportSpecificationAttribute、ExportManager、IExportManager、ImportManager、IImportManager
Extensions类,该类主要通过泛型操作方法,把枚举和实体的实例中的一些数据填充到选择列表实例中,从而为下拉框控件的实例化提供数据支撑。
PropertyByName<T>类,该类及其属性成员用于存储Execl1个指定单元格的的相关数据,为该单元格的导入/导出操作提供数据支撑。
PropertyManager<T>类,该类及其属性成员用于存储导入/导出操作时,整个Execl表所需所相关数据及其实现方法。
ExportedAttributeType枚举,相关商品信息的导出操作的方式,共有3种方式:无限制/按照商品属性导出/按照(商品)规格属性导出。
ImportProductMetadata类,通过该类及其属性成员,对Excel表导入操作中所产生的相关数据进行存储,为把这些数据持久化存储到数据库的表中提供数据支撑。
ExportProductAttribute类,通过该类及其属性成员用于存储,在指定商品的导出操作中,需要一起被导出的指定商品相关属性的相关数据,为商品的导出操作提供扩展性的数据支撑。
ExportSpecificationAttribute类,通过该类及其属性成员用于存储,在指定商品的导出操作中,需要一起被导出的指定商品规格相关属性的相关数据,为商品的导出操作提供扩展性的数据支撑。
ExportManager类,继承于IExportManager接口,该类定义实现了当前程序通过“EPPlus”中间件把数据从当前程序导出到Excel文件中所需要的所有的方法成员。
IExportManager接口,该类定义实现了当前程序通过“EPPlus”中间件把Excel文件中的数据,导入到当前程序所连接数据库的指定表中的所有的方法成员。
ImportManager类,继承于IImportManager接口,该类定义实现了当前程序通过“EPPlus”中间件把数据从当前程序导出到Excel文件中所需要的所有的方法成员。
IImportManager接口,继承于该接口的类,定义实现了当前程序通过“EPPlus”中间件把Excel文件中的数据,导入到当前程序所连接数据库的指定表中的所有的方法成员。
1、重构Nop.Services.Localization.ILocalizationService和Nop.Services.Localization.LocalizationService,取消对GetLocalizedEnumAsync方法的注释。
2、Nop.Services.Installation.InstallationService类中定义下列方法:
Nop.Services.Installation.InstallationService.InstallCountriesAndStatesAsync
Nop.Services.Installation.InstallationService.InstallCurrenciesAsync
Nop.Services.Installation.InstallationService.InstallMeasuresAsync
Nop.Services.Installation.InstallationService.InstallSampleCustomersAsync
3、取消Nop.Services.Installation.InstallationService.InstallRequiredDataAsync方法中下列语句中的注释:
await InstallMeasuresAsync(regionInfo);
await InstallCurrenciesAsync(cultureInfo, regionInfo);
await InstallCountriesAndStatesAsync();
4、取消Nop.Services.Installation.InstallationService.InstallSampleDataAsync方法中下列语句中的注释:
await InstallSampleCustomersAsync();
5、重构Nop.Web.Framework.Infrastructure.DependencyRegistrar.Register方法,取消下列语句前的注释:
services.AddScoped<IExportManager, ExportManager>();
services.AddScoped<IImportManager, ImportManager>();
6、按F5执行安装页面,数据库中已经持久化存储了地址录默认数据。
对以上功能更为具体实现和注释见:22-04-08-042_Nop_4.40.4(数据导入、导出服务与地址录默认数据的初始化安装)。