Exemplo n.º 1
0
        /// <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);
        }
Exemplo n.º 2
0
        /// <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);
        }