Traduções desta página:

Ferramentas do usuário

Ferramentas do site


05_curso_antigo:r2018:alunos:trabalho_final:maira.neves:codigo

Função lista_compras

lista_compras = function(cafe, refeicao, jaca, multiplos = 0, listasobras = NULL, listacafe, listarefeicao, listajaca){ # cria a função
  ### VERIFICANDO PARÂMETROS DECLARADOS
  # Numéricos
  if(is.numeric(cafe) == FALSE){ # verifica se cafe é numérico
    stop("cafe não é numérico") # se não for, dá um erro avisando
  }
  if(is.numeric(refeicao) == FALSE){ # verifica se refeicao é numérico
    stop("refeicao não é numérico") # se não, for dá um erro avisando
  }
  if(is.numeric(jaca) == FALSE){ # verifica se jaca é numérico
    stop("jaca não é numérico") # se não for, dá um erro avisando
  }
  if(is.numeric(multiplos) == FALSE){ # verifica se multiplos é numérico
    stop("multiplos não é numérico") # se não for, dá um erro avisando
  }
  # listasobras
  if(is.null(listasobras) == FALSE){ # verifica se foi oferecido sobras. Se foi, faz verificações adicionais
    if(is.data.frame(listasobras) == FALSE){ # verifica se listasobras é um data.frame
      stop("listasobras deve ser declarado como data.frame") # se não for, dá um erro avisando
    }
    if(ncol(listasobras) != 3){ # verifica se o número de colunas está correto
      stop("número de colunas incorreto em listasobras") # se não estiver, dá um erro avisando
    }
    if(is.numeric(listasobras[,2]) == FALSE){ # verifica se a segunda coluna é numérica
      stop("verifique a segunda coluna de listasobras") # se não for, dá um erro avisando
    }
  }
  # listas
  if(is.data.frame(listacafe) == FALSE | is.data.frame(listarefeicao) == FALSE | is.data.frame(listajaca) == FALSE){ # verifica se as listas são data.frames
    stop("as listas de receitas devem ser declaradas como data.frame") # se não forem, dá um erro avisando
  }
  if(ncol(listacafe) != 5 | ncol(listarefeicao) != 5 | ncol(listajaca) != 5){ # verifica se o número de colunas das listas está correto
    stop("número de colunas incorreto nas listas") # se não estiverem, dá um erro avisando
  }
  if(is.numeric(listacafe[,3]) == FALSE | is.numeric(listarefeicao[,3]) == FALSE | is.numeric(listajaca[,3]) == FALSE){ # verifica se a terceira coluna de cada lista é numérica
    stop("verifique a segunda coluna de sobras") # se não for, dá um erro avisando
  }
  
  ### ESCREVENDO VARIÁVEIS PARA OUTPUT
  lista_receitas = data.frame(matrix(ncol=2, nrow=0)) # vai acumular o nome e o preparo das receitas escolhidas
  colnames(lista_receitas) = c("RECEITA", "PREPARO") # nomes das colunas
  lista_supermercado = data.frame(matrix(ncol=3, nrow=0)) # vai ser usado como lista de compras
  colnames(lista_supermercado) = c("INGREDIENTE", "QUANTIDADE", "UNIDADE DE MEDIDA") # nomes das colunas
  lista_nao_usado = data.frame(matrix(ncol=3, nrow=0)) # para mostrar as sobras que não foi possível usar
  colnames(lista_nao_usado) = c("INGREDIENTE", "QUANTIDADE", "UNIDADE DE MEDIDA") # nomes das colunas
  
  ### VERIFICANDO SOBRAS
  # Estrutura de testes escolhida para verificar os ingredientes da lista de sobras com quantidades maiores que zero:
  # Verificar se existe receitas com aquele ingrediente disponíveis em cafe, refeicao, ou jaca conforme
  # determinado pelos parâmetros declarados
  # Para cada categoria de receita, identificar todas as receitas que contém o ingrediente, e verificar se tem mais ou menos
  # receitas do que o requisitado para aquela categoria.
  # Se houverem mais receitas do que o requisitado, sorteia as receitas a serem usadas.
  # Se foram solicitadas receitas suficientes, usar todas.
  # Se não houverem receitas suficientes para aquele ingrediente, incluir na lista dos ingredientes não utilizados.
  # Remover a quantidade do ingrediente da lista e continuar o procedimento para os demais ingredientes
  sobras = listasobras # atribuindo listasobras a uma nova variável para poder mexer nos valores sem perder a informação do input
  for(i in 1:nrow(sobras)){ # iterar sobre cada ingrediente da sobra
    # CAFE
    if(sobras[i,2] > 0){ # ver se realmente existe item disponível
      if(cafe > 0){ # verifica se foram solicitadas receitas da categoria cafe
        ingrediente_no_cafe = listacafe[listacafe$INGREDIENTE == sobras[i,1],] # procurando o ingrediente na lista de cafe
        if(nrow(ingrediente_no_cafe) > 0){ # ver se encontrou alguma receita pra usar o ingrediente
          if(cafe < nrow(ingrediente_no_cafe)){ # verifica se existem mais receitas do que o permitido para cafe
            sorteio = sample(1:nrow(ingrediente_no_cafe), cafe) # sorteia o número de receitas necessárias
            lista_receitas = rbind(lista_receitas, ingrediente_no_cafe[sorteio, c(1,5)]) # incluir receitas escolhidas na lista
            lista_supermercado = rbind(lista_supermercado, listacafe[listacafe$RECEITA %in% ingrediente_no_cafe[sorteio, 1], c(2, 3, 4)]) # incluir todos ingredientes das receitas sorteadas na lista de compras
            cafe = 0 # zerar a quantidade de receitas da categoria cafe disponíveis
            if(length(unique(ingrediente_no_cafe[sorteio,4])) == 1){ # verifica se unidades de medida do ingrediente são iguais
              sobras[i,2] = sobras[i,2] - sum(ingrediente_no_cafe[sorteio,3]) # tira o ingrediente das sobras
            }else{ # se unidades de medida do ingrediente não forem iguais
              stop("Verifique as unidades de medida da tabela cafe") # dá erro
            }
          }else{ # se tiver mais receitas cafe declaradas do que receitas com o ingrediente
            lista_receitas = rbind(lista_receitas, ingrediente_no_cafe[, c(1,5)]) # incluir receitas na lista
            lista_supermercado = rbind(lista_supermercado, listacafe[listacafe$RECEITA %in% ingrediente_no_cafe[, 1], c(2, 3, 4)]) # incluir todos ingredientes das receitas na lista de compras
            cafe = cafe - nrow(ingrediente_no_cafe) # diminui o número de receitas disponíveis em cafe
            if(length(unique(ingrediente_no_cafe[,4])) == 1){ # verifica se unidades de medida do ingrediente são iguais
              sobras[i,2] = sobras[i,2] - sum(ingrediente_no_cafe[,3]) # Tira o ingrediente usado das sobras
            }else{ # se unidades de medida do ingrediente não forem iguais
              stop("Verifique as unidades de medida da tabela cafe") # dá erro
            }
          }
        }
      }
    }
    # REFEIÇÃO
    if(sobras[i,2] > 0){ # ver se realmente existe item disponível
      if(refeicao > 0){ # verifica se foram solicitadas receitas da categoria refeicao
        ingrediente_na_refeicao = listarefeicao[listarefeicao$INGREDIENTE == sobras[i,1],] # procurando o ingrediente na lista de refeicao
        if(nrow(ingrediente_na_refeicao) > 0){ # ver se encontrou alguma receita pra usar o ingrediente
          if(refeicao < nrow(ingrediente_na_refeicao)){ # verifica se existem mais receitas do que o permitido para refeicao
            sorteio = sample(1:nrow(ingrediente_na_refeicao), refeicao) # sorteia o número de receitas necessárias
            lista_receitas = rbind(lista_receitas, ingrediente_na_refeicao[sorteio, c(1,5)]) # incluir receitas escolhidas na lista
            lista_supermercado = rbind(lista_supermercado, listarefeicao[listarefeicao$RECEITA %in% ingrediente_na_refeicao[sorteio, 1], c(2, 3, 4)]) # incluir todos ingredientes das receitas sorteadas na lista de compras
            refeicao = 0 # zerar a quantidade de receitas da categoria refeicao disponíveis
            if(length(unique(ingrediente_na_refeicao[sorteio,4])) == 1){ # verifica se unidades de medida do ingrediente são iguais
              sobras[i,2] = sobras[i,2] - sum(ingrediente_na_refeicao[sorteio,3]) # tira o ingrediente das sobras
            }else{ # se unidades de medida do ingrediente não forem iguais
              stop("Verifique as unidades de medida da tabela refeicao") # dá erro
            }
          }else{ # se tiver mais receitas refeicao declaradas do que receitas com o ingrediente
            lista_receitas = rbind(lista_receitas, ingrediente_na_refeicao[, c(1,5)]) # incluir receitas na lista
            lista_supermercado = rbind(lista_supermercado, listarefeicao[listarefeicao$RECEITA %in% ingrediente_na_refeicao[, 1], c(2, 3, 4)]) # incluir todos ingredientes das receitas na lista de compras
            refeicao = refeicao - nrow(ingrediente_na_refeicao) # diminui o número de receitas disponíveis em cafe
            if(length(unique(ingrediente_na_refeicao[,4])) == 1){ # verifica se unidades de medida do ingrediente são iguais
              sobras[i,2] = sobras[i,2] - sum(ingrediente_na_refeicao[,3]) # tira a quantidade do ingrediente das sobras
            }else{ # se unidades de medida do ingrediente forem diferentes
              stop("Verifique as unidades de medida da tabela refeicao") # dá erro
            }
          }
        }
      }
    }
    # PÉ NA JACA
    if(sobras[i,2] > 0){ # ver se realmente existe item disponível
      if(jaca > 0){ # verifica se foram solicitadas receitas da categoria jaca
        ingrediente_na_jaca = listajaca[listajaca$INGREDIENTE == sobras[i,1],] # procurando o ingrediente na lista de jaca
        if(nrow(ingrediente_na_jaca) > 0){ # ver se encontrou alguma receita pra usar o ingrediente
          if(jaca < nrow(ingrediente_na_jaca)){ # verifica se existem mais receitas do que o permitido para jaca
            sorteio = sample(1:nrow(ingrediente_na_jaca), jaca) # sorteia o número de receitas necessárias
            lista_receitas = rbind(lista_receitas, ingrediente_na_jaca[sorteio, c(1,5)]) # incluir receitas escolhidas na lista
            lista_supermercado = rbind(lista_supermercado, listajaca[listajaca$RECEITA %in% ingrediente_na_jaca[sorteio, 1], c(2, 3, 4)]) # incluir todos ingredientes das receitas sorteadas na lista de compras
            jaca = 0 # zerar a quantidade de receitas da categoria jaca disponíveis
            if(length(unique(ingrediente_na_jaca[sorteio,4])) == 1){ # verifica se unidades de medida do ingrediente são iguais
              sobras[i,2] = sobras[i,2] - sum(ingrediente_na_jaca[sorteio,3]) # tira o ingrediente das sobras
            }else{ # se unidades de medida do ingrediente forem diferentes
              stop("Verifique as unidades de medida da tabela jaca") # dá erro
            }
          }else{ # se tiver mais receitas jaca declaradas do que receitas com o ingrediente
            lista_receitas = rbind(lista_receitas, ingrediente_na_jaca[, c(1,5)]) # incluir receitas na lista
            lista_supermercado = rbind(lista_supermercado, listajaca[listajaca$RECEITA %in% ingrediente_na_jaca[, 1], c(2, 3, 4)]) # incluir todos ingredientes das receitas na lista de compras
            jaca = jaca - nrow(ingrediente_na_jaca) # diminui o número de receitas disponíveis em cafe
            if(length(unique(ingrediente_na_jaca[,4])) == 1){ # verifica se unidades de medida do ingrediente são iguais
              sobras[i,2] = sobras[i,2] - sum(ingrediente_na_jaca[,3]) # tira o ingrediente das sobras
            }else{ # se unidades de medida do ingrediente forem diferentes
              stop("Verifique as unidades de medida da tabela jaca") # dá erro
            }
          }
        }
      }
    }
    if(sobras[i,2] > 0){ # verificar se a quantidade do ingrediente ainda é maior que zero para adicionar a lista de ingredientes não usados
      lista_nao_usado = rbind(lista_nao_usado, sobras[i,]) # incluir o ingrediente, quantidade e unidade de medida na lista de não usados
    }
  }
  
  ### INCLUIR RECEITAS
  # cafe
  if(cafe > 0){ # ver se ainda precisa escolher mais receitas para cafe
    sorteio = sample(1:nrow(listacafe), cafe) # se sim, sortear o número necessário
    lista_receitas = rbind(lista_receitas, listacafe[sorteio, c(1,5)]) # incluir receitas escolhidas na lista
    lista_supermercado = rbind(lista_supermercado, listacafe[listacafe$RECEITA %in% listacafe[sorteio, 1], c(2, 3, 4)]) # incluir todos ingredientes das receitas sorteadas na lista de compras
  }
  # refeicao
  if(refeicao > 0){ # ver se ainda precisa escolher mais receitas para refeicao
    sorteio = sample(1:nrow(listarefeicao), refeicao) # se sim, sortear o número necessário
    lista_receitas = rbind(lista_receitas, listarefeicao[sorteio, c(1,5)]) # incluir receitas escolhidas na lista
    lista_supermercado = rbind(lista_supermercado, listarefeicao[listarefeicao$RECEITA %in% listarefeicao[sorteio, 1], c(2, 3, 4)]) # incluir todos ingredientes das receitas sorteadas na lista de compras
  }
  # jaca
  if(jaca > 0){ # ver se ainda precisa escolher mais receitas para jaca
    sorteio = sample(1:nrow(listajaca), jaca) # se sim, sortear o número necessário
    lista_receitas = rbind(lista_receitas, listajaca[sorteio, c(1,5)]) # incluir receitas escolhidas na lista
    lista_supermercado = rbind(lista_supermercado, listajaca[listajaca$RECEITA %in% listajaca[sorteio, 1], c(2, 3, 4)]) # incluir todos ingredientes das receitas sorteadas na lista de compras
  }
  
  ### MULTIPLICANDO AS QUANTIDADES DE UMA REFEIÇÃO PRINCIPAL PARA REFEIÇÃO MÚLTIPLA
  if(multiplos > 1){ # se foi declarado o numero de pessoas para refeicao multipla
    lista_receitas_refeicao = lista_receitas[lista_receitas$RECEITA %in% listarefeicao$RECEITA,] # encontrar as receitas da categoria refeicao na lista de receitas
    sorteio = sample(1:nrow(lista_receitas_refeicao), 1) # sortear uma receita
    multiplicacao = listarefeicao[listarefeicao$RECEITA %in% listarefeicao[sorteio, 1], c(2, 3, 4)] # cria dataframe com os ingredientes a serem multiplicados
    multiplicacao[,2] = lapply(multiplicacao, function(x) x * (multiplos - 1)) # multiplicar os ingredientes vezes o número de multiplos -1 pois os ingredientes já foram adicionados na lista de supermercado uma vez
    lista_supermercado = rbind(lista_supermercado, multiplicacao) # incluir todos ingredientes multiplicados na lista de compras
    # pegar ingredientes desta refeição e somar multiplos-1 vezes cada ingrediente
  }
  
  ### UNIFICANDO MESMOS INGREDIENTES DA LISTA DE SUPERMERCADO
  supermercado_exclusiva = unique(lista_supermercado$INGREDIENTE) # criar lista com cada ingrediente sem repetição.
  lista_supermercado_unificada = data.frame(matrix(nrow = length(supermercado_exclusiva), ncol = 3)) # criar nova dataframe para output da lista de supermercado sem repetição de ingredientes
  colnames(lista_supermercado_unificada) = c("INGREDIENTE", "QUANTIDADE", "UNIDADE DE MEDIDA") # nomear colunas
  lista_supermercado_unificada$INGREDIENTE = supermercado_exclusiva # preencher a coluna de ingredientes
  for(i in 1:length(supermercado_exclusiva)){ # iterar sobre cada ingrediente sem repetição
    quantidade = 0 # criar uma variável para acumular a quantidade do ingrediente
    for(j in 1:nrow(lista_supermercado)){ # olhar para cada linha da lista de supermercado com repetição
      if(lista_supermercado[j, 1] == supermercado_exclusiva[i]){ # procurando o ingrediente em questão
        if(is.na(lista_supermercado_unificada[i, 3]) == TRUE){ # ver se já tinha unidade de medida atribuída ao ingrediente
          lista_supermercado_unificada[i, 3] = lista_supermercado[j, 3] # se não tinha unidade de medida, pegar
          quantidade = quantidade + lista_supermercado[j, 2] # e somar a quantidade pra somatório final
        }else if(lista_supermercado_unificada[i, 3] == lista_supermercado[j, 3]){ # se ja tiver unidade de medida, ver se são iguais
          quantidade = quantidade + lista_supermercado[j, 2] # somar quantidades caso unidades sejam iguais
        }else if(lista_supermercado_unificada[i, 3] != lista_supermercado[j, 3]){ # se unidades de medida forem diferentes, dar um erro
          stop("Verifique as unidades de medidas. Para um mesmo ingrediente deve usar a mesma unidade de medida.") # emite o erro
        }
      }
    }
    lista_supermercado_unificada[i, 2] = quantidade # atribuir a somatória de quantidades a lista final
  }
  
  ### SUBTRAIR DA LISTA DE SUPERMERCADO OS ITENS DA SOBRA
  if(is.null(listasobras) == FALSE){ # se foi declarada listasobras
    for(i in 1:nrow(listasobras)){ # iterar sobre cada item das sobras
      if(listasobras[i, 1] %in% lista_supermercado_unificada$INGREDIENTE){ # se o item das sobras está presente na lista de compras
        lista_supermercado_unificada[lista_supermercado_unificada$INGREDIENTE == listasobras[i, 1], 2] = lista_supermercado_unificada[lista_supermercado_unificada$INGREDIENTE == listasobras[i, 1], 2] - listasobras[i, 2] # e subtrair a quantidade na sobra da quantidade da lista de supermercado
        if(lista_supermercado_unificada[lista_supermercado_unificada$INGREDIENTE == listasobras[i, 1], 2] <= 0){ # se essa subtração zerar o ingrediente
          lista_supermercado_unificada = lista_supermercado_unificada[!(lista_supermercado_unificada$INGREDIENTE == listasobras[i, 1]),] # remover o ingrediente da lista
        }
      }
    }
  }
  
  ### OUTPUT
  if(nrow(lista_receitas) != 0){ # verifica se lista de receitas tem alguma coisa dentro pra imprimir
    cat(paste("Receitas escolhidas e preparo (ou site que te ensina o preparo)\n\n")) # output de receitas
    cat(for(i in 1:nrow(lista_receitas)){ # iterar sobre cada linha do arquivo com as receitas usadas
      print(lista_receitas[i,])} # imprimindo cada linha
      , "\n\n", "==========", "\n\n") # fazer um separador bonitinho
  }
  if(nrow(lista_supermercado_unificada) != 0){ # verifica se lista de supermercado tem coisa dentro para imprimir
    cat(paste("Lista de compras de supermercado\n\n")) # output da lista de supermercado
    cat(for(j in 1:nrow(lista_supermercado_unificada)){ # iterando sobre cada linha do arquivo com os itens a ser comprados
      print(lista_supermercado_unificada[j,])} # imprimindo cada linha
      , "\n\n", "==========", "\n\n") # fazendo um separador bonitinho
  }
  if(nrow(lista_nao_usado) != 0){ # verifica se tem itens não usados nas sobras
    cat(paste("Sinto muito, esses ingredientes vão ficar sobrando na dispensa mais um tempo.\n\n")) # output dos não usados na sobras
    cat(for(k in 1:nrow(lista_nao_usado)){ # iterando sobre cada linha dos itens não usados
      print(lista_nao_usado[k,])} # imprimindo cada linha
    )}
}
05_curso_antigo/r2018/alunos/trabalho_final/maira.neves/codigo.txt · Última modificação: 2020/08/12 06:04 (edição externa)