KeyValuePair in

C#

foreach ()KeyValuePair<string, object> item in ViewData)

foreach (KeyValuePair<string, object> item in ViewData) 
//就是一个for 循环,相当于
KeyValuePair<string, object> item;
for (int i =0;i<ViewData.length; i++){
item = ViewData.get(i);
...
}
06-14
public Dictionary<string, List<BasicEntity>> ValidateProcess(string excelFile) { var readExcelResp = _excelReader.ReadExcel(excelFile); foreach (var keyValuePair in readExcelResp) { foreach (var basicEntity in keyValuePair.Value) { var validationResult = ExecuteValidate(basicEntity); if (!validationResult.IsValid) { basicEntity.MigrationStatus = MigrationStatus.PreValidationFailed; foreach (var validationResultError in validationResult.Errors) { excelErrorLogService.AddErrorLog(basicEntity.MigrationRowNum.ToString(), validationResultError.ErrorMessage, keyValuePair.Key); } } } if (keyValuePair.Value.Any()) { var verifyDuplicate = VerifyDuplicate(keyValuePair.Value,keyValuePair.Key); if (verifyDuplicate.Any()) { var type = typeof(IValidator<>).MakeGenericType(keyValuePair.Value[0].GetType()); var validator = provider.GetService(type) ; if (validator != null) { var methodInfo = validator.GetType().GetMethod("DuplicateHandler", new[] {verifyDuplicate.GetType() }); methodInfo?.Invoke(validator, new object?[] { verifyDuplicate }); } } } } return readExcelResp; } public List<BasicEntity> VerifyDuplicate(List<BasicEntity> checkList, String sheetName) { var verifySet = new HashSet<string>(); var sameList = new List<BasicEntity>(); var identity = checkList[0].GetIdentity(); if (!string.IsNullOrEmpty(identity)) { var fields = identity.Split(""); foreach (var basicEntity in checkList) { List<string> fieldsValue = new(); foreach (var field in fields) { fieldsValue.Add(basicEntity.GetType() .GetProperty(field, BindingFlags.IgnoreCase | BindingFlags.Public | BindingFlags.Instance).GetValue(basicEntity) ?.ToString()); } var values = string.Join("", fieldsValue); if (verifySet.Contains(values)) { basicEntity.MigrationStatus = MigrationStatus.PreValidationFailed; sameList.Add(basicEntity); _excelErrorLogService.AddErrorLog(basicEntity.MigrationRowNum.ToString(), $"Fields {identity} values repetition", sheetName); } else { verifySet.Add(values); } } } return sameList; } 优化这段代码
06-15
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值