/// <summary> /// A partir das listas de string que representam cada linha da lista de material em Excel, cria os objetosComparacaoLista para cada estrutura /// </summary> /// <param name="pListaLinhasListaMateriais"></param> /// <returns></returns> public static Dictionary <string, List <ObjetoComparacaoLista> > CriaObjetosComparacaoListaByTxt(List <string> pListaLinhasListaMateriais) { string estruturaVigenteLista = ""; Dictionary <string, List <ObjetoComparacaoLista> > dicObjetosPorEstrutura = new Dictionary <string, List <ObjetoComparacaoLista> >(); for (int i = 0; i < pListaLinhasListaMateriais.Count; i++) { string objetoLista = pListaLinhasListaMateriais[i]; if (objetoLista.Count() < 2) { continue; } if (VerificaLinhaTXTEstrutura(objetoLista)) { estruturaVigenteLista = objetoLista.Split(new string[] { " - " }, StringSplitOptions.RemoveEmptyEntries).Last(); continue; } ObjetoComparacaoLista objetoCriado = null; //CHAPA if (objetoLista.Substring(14, 24).Replace(" ", "").Contains("C")) { objetoCriado = new ChapaComparacaoLista(objetoLista, estruturaVigenteLista); } //CANTONEIRA else { objetoCriado = new CantoneiraComparacaoLista(objetoLista, estruturaVigenteLista); } if (!dicObjetosPorEstrutura.ContainsKey(estruturaVigenteLista)) { dicObjetosPorEstrutura.Add(estruturaVigenteLista, new List <ObjetoComparacaoLista>()); } dicObjetosPorEstrutura[estruturaVigenteLista].Add(objetoCriado); } return(dicObjetosPorEstrutura); }
/// <summary> /// A partir das listas de string que representam cada linha da lista de material em Excel, cria os objetosComparacaoLista para cada estrutura /// </summary> /// <param name="pListaLinhasListaMateriais"></param> /// <returns></returns> public static Dictionary <string, List <ObjetoComparacaoLista> > CriaObjetosComparacaoListaByExcel(List <List <string> > pListaLinhasListaMateriais) { string estruturaVigenteLista = ""; Dictionary <string, List <ObjetoComparacaoLista> > dicObjetosPorEstrutura = new Dictionary <string, List <ObjetoComparacaoLista> >(); for (int i = 0; i < pListaLinhasListaMateriais.Count; i++) { List <string> objetoLista = pListaLinhasListaMateriais[i]; if (i > 10 && pListaLinhasListaMateriais[i - 4][0].Equals("L I S T A D E M A T E R I A I S") && pListaLinhasListaMateriais[i + 1][0].Contains("Conj. Soldado")) { estruturaVigenteLista = objetoLista[0]; } bool eCalota = objetoLista[4].ToLower().Contains("calota") || (objetoLista[4].Contains("d") && objetoLista[4].Contains("r")); if (objetoLista.Count < 9 || string.IsNullOrEmpty(objetoLista[1]) || string.IsNullOrEmpty(objetoLista[4]) || (!eCalota && string.IsNullOrEmpty(objetoLista[6])) || string.IsNullOrEmpty(objetoLista[7]) || string.IsNullOrEmpty(objetoLista[8])) { continue; } string posicao = objetoLista[1].ToString().Split(new string[] { ".0" }, StringSplitOptions.RemoveEmptyEntries).First().Split(new string[] { ",0" }, StringSplitOptions.RemoveEmptyEntries).First().Replace(" ", ""); string posicaoSemMaterial = posicao.Last().Equals('H') || posicao.Last().Equals('G') || posicao.Last().Equals('h') || posicao.Last().Equals('g') ? posicao.Remove(posicao.Count() - 1) : posicao; //posicaoStringNumero so serve pra testar converter pra double no try e garantir que é uma linha de uma peça na lista string posicaoStringNumero = posicaoSemMaterial; if (Char.IsLetter(posicaoSemMaterial.Last())) { posicaoStringNumero = posicaoStringNumero.Remove(posicaoStringNumero.Count() - 1); } if (Char.IsLetter(posicaoSemMaterial.First())) { posicaoStringNumero = posicaoStringNumero.Remove(0, 1); } try { System.Convert.ToDouble(posicaoStringNumero); } catch { continue; } ObjetoComparacaoLista objetoCriado = null; //CHAPA if (objetoLista[4].Contains("C")) { objetoCriado = new ChapaComparacaoLista(objetoLista, estruturaVigenteLista); } //CANTONEIRA else { objetoCriado = new CantoneiraComparacaoLista(objetoLista, estruturaVigenteLista); } if (!dicObjetosPorEstrutura.ContainsKey(estruturaVigenteLista)) { dicObjetosPorEstrutura.Add(estruturaVigenteLista, new List <ObjetoComparacaoLista>()); } dicObjetosPorEstrutura[estruturaVigenteLista].Add(objetoCriado); } return(dicObjetosPorEstrutura); }