Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

uoston.bs

Sistema de Contagem de Refeições

Recommended Posts

Galera, bom dia! 

Estou com um problema que acredito ser "simples", mas ainda não conseguir resolver.

Desenvolvi uma aplicação simples em PHP que faz a contagem de refeições através de dados registrados em um txt, pego os dados do txt usando o substring para determinar o valor de cada coluna, o programa funciona até que bem, porém quando tenho alteração de DATA, mas com mesma faixa de horário ele não imprime a quantidade de refeição (seja ceia, café, almoço ou jantar).

logo o que queria é que o programa além de fazer as impressões que já faz, imprimir também a quantidade de refeições quando a data for alterada, pois a contagem é feita por dia.

Segue meu código completo abaixo:

<?php set_time_limit(60); ?>
<?php require_once('conexao/conectar.php'); ?>
<?php date_default_timezone_set('America/Sao_Paulo'); ?>

<?php header("Content-Type: text/html; charset=ISO-8859-1",true) ; ?>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<link rel="shortcut icon" href="icone/icone.ico" type="image/x-icon" />
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
<title>Index</title>
<style>


</head>
<style>
.titulo{

    background: linear-gradient(#3555a2, #3555a2);
      background: -moz-linear-gradient(#3555a2, #3555a2);
      background: -ms-linear-gradient(#3555a2, #3555a2);
      background: -o-linear-gradient(#3555a2, #3555a2);
      background: -webkit-linear-gradient(#3555a2, #3555a2);
      background-color: #57944d;
    color: #FFF;
      box-shadow: #57944d 0 0 15px;
      border-top: 2px solid #3555a2;
      border-bottom: 2px solid #3555a2;
      -moz-border-radius:4px;
    -webkit-border-radius:4px;
    border-radius:4px;
    font-family:Tahoma, Geneva, sans-serif;
}
.lista{

    background: linear-gradient(#3555a2, #3555a2);
      background: -moz-linear-gradient(#3555a2, #3555a2);
      background: -ms-linear-gradient(#3555a2, #3555a2);
      background: -o-linear-gradient(#3555a2, #3555a2);
      background: -webkit-linear-gradient(#3555a2, #3555a2);
      background-color: #57944d;
    color: #FFF;
      box-shadow: #57944d 0 0 15px;
      border-top: 2px solid #3555a2;
      border-bottom: 2px solid #3555a2;
      -moz-border-radius:4px;
    -webkit-border-radius:4px;
    border-radius:4px;
    font-family:Tahoma, Geneva, sans-serif;
}
</style>
<style>
.a{
    text-decoretion: underline;
    color: #FFF;
}
.a:hover{
    color: #CD2626;
}

#preloader {
    position: absolute;
    left: 0px;
    right: 0px;
    bottom: 0px;
    top: 0px;
    background: #ccc;
}

</style>

<body>

<?php


$count = 0;


if (!function_exists("GetSQLValueString")) {
function GetSQLValueString($theValue, $theType, $theDefinedValue = "", $theNotDefinedValue = "") 
{
  if (PHP_VERSION < 6) {
    $theValue = get_magic_quotes_gpc() ? stripslashes($theValue) : $theValue;
  }

  $theValue = function_exists("mysql_real_escape_string") ? mysql_real_escape_string($theValue) : mysql_escape_string($theValue);

  switch ($theType) {
    case "text":
      $theValue = ($theValue != "") ? "'" . $theValue . "'" : "NULL";
      break;    
    case "long":
    case "int":
      $theValue = ($theValue != "") ? intval($theValue) : "NULL";
      break;
    case "double":
      $theValue = ($theValue != "") ? doubleval($theValue) : "NULL";
      break;
    case "date":
      $theValue = ($theValue != "") ? "'" . $theValue . "'" : "NULL";
      break;
    case "defined":
      $theValue = ($theValue != "") ? $theDefinedValue : $theNotDefinedValue;
      break;
  }
  return $theValue;
}


$contador = 0;
$data_inicial = $_POST['inicial'];
$data_final = $_POST['final'];
$empresa = $_POST['tipo'];
//$data_teste = date("d/m/Y");
$data_arquivoin = $_POST['inicial'];
$data_arquivofi = $_POST['final'];

$quebra =  chr(13).chr(10);


$escrever = "Empresa INDU. REUN. * RAYMUNDO DA FONTE *".PHP_EOL;
$area = "Relatorio: $empresa".PHP_EOL;
$cabecalho = "Relatorio $empresa de $data_arquivoin a $data_arquivofi $quebra";

$titulos = "$quebra Data          Hora       Cartao            Colaborador           $quebra ";
$formatacao = "----------------------------------------------------------------- $quebra $quebra";

$normal = fopen("Relatorios/Relatorio $empresa de $data_inicial a $data_final.txt", "w");
$texto1 = fwrite($normal, $escrever);
$texto2 = fwrite($normal, $area);
$texto3 = fwrite($normal, $cabecalho);
$texto4 = fwrite($normal, $titulos);
$texto5 = fwrite($normal, $formatacao);

//Variaveis para determinar qual o tipo da refeição que foi realizada.
$cafe_inicial = '05';
$cafe_final = '08';
$almoco_inicial = '11';
$almoco_final = '14';
$jantar_inicial = '18';
$jantar_final = '20';
$ceia_inicial = '00';
$ceia_final = '02';

//Variaveis para calculo de refeição diaria
$cont_cafe = 0;
$cont_almoco = 0;
$cont_jantar = 0;
$cont_ceia = 0;

$cont_cresauto = 0;
$cont_asa = 0;
$cont_ws = 0;
$cont_nbs = 0;
$cont_total = 0;
$cont_pm = 0;
$cont_only = 0;
$cont_helna = 0;
$cont_wjm = 0;

$arquivo = "Relatorios/Relatorio $empresa de $data_inicial a $data_final.txt";
    $ponteiro = '//192.168.4.39//Portaria//bilhetes-p.txt';
    $abrir = fopen($ponteiro, 'r');
    $total_linhas = 0;    
        if(file_exists($ponteiro)){
                
            do{
                    
                $conteudo = fgets($abrir, 3500);
                $cartao = substr($conteudo, 27, -5);
                $data = substr($conteudo, 4, 10);
                $hora = substr($conteudo, 15, -25);
                $hora_cont = substr($conteudo, 15, -22);
                
                            
                            
            $query_row = mysql_query("SELECT nome, cartao, empresa FROM catracas WHERE cartao = '$cartao'");
            $row = ($query_row)or die(mysql_error());
            $row_row = mysql_fetch_assoc($row);
            $totalRows_row = mysql_num_rows($row);
                        
            $colaborador = $row_row['nome'];
            
            $data_mod = str_replace("/", "-", $data);
                //echo "<br>$empresa<br>";
                
            
            if($empresa == 'Brilux'){
            
            
            
            if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
            
            if($cartao == $row_row['cartao']){                
                $cont_total = $cont_total + 1;
                    if($hora > $ceia_final and $cont_ceia > 1){
                        $dados = fwrite($normal, "$quebra Total Ceia ----------->>>>> $cont_ceia $quebra $quebra");
                        $cont_ceia = 0;
                    }
                    
                            if($hora > $cafe_final and $cont_cafe > 1){
                        $dados = fwrite($normal, "$quebra Total Cafe ----------->>>>> $cont_cafe $quebra $quebra");
                        $cont_cafe = 0;
                    }
                    
                        if($hora > $almoco_final and $cont_almoco> 1){
                        $dados = fwrite($normal, "$quebra Total Almoco ----------->>>>> $cont_almoco $quebra $quebra");
                        $cont_almoco = 0;
                    }
                    
                        if($hora == $ceia_inicial and $cont_jantar > 1){
                        $dados = fwrite($normal, "$quebra Total Jantar ----------->>>>> $cont_jantar $quebra $quebra");
                        $cont_jantar = 0;
                    }
                                        
                    
                    
                    if($hora >= $ceia_inicial and $hora <= $ceia_final){
                        $cont_ceia = $cont_ceia +1;
                    }
                    
                    if($hora >= $cafe_inicial and $hora <= $cafe_final){
                        $cont_cafe = $cont_cafe +1;
                    }
                    
                    if($hora >= $almoco_inicial and $hora <= $almoco_final){
                        $cont_almoco = $cont_almoco+1;
                    }
                    
                    if($hora >= $jantar_inicial and $hora <= $jantar_final){
                        $cont_jantar = $cont_jantar +1;
                    }
                    
                    
                    $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                
                    
                    
                    }    
                    
                }

            }
            
            if($empresa == 'cresauto'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='Cresauto'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_cresauto = $cont_cresauto +1;    
                    }
                }
            }
            
            if($empresa == 'asa'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='Asa de Prata'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_asa = $cont_asa +1;    
                    }
                }
            }
            
            if($empresa == 'ws'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='WS'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_ws = $cont_ws +1;    
                    }
                }
            }
            
            if($empresa == 'nbs'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='NBS'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_nbs = $cont_nbs +1;    
                    }
                }
            }
            
            if($empresa == 'pm'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='PM'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_pm = $cont_pm +1;    
                    }
                }
            }
            
            if($empresa == 'only'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='ONLY'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_only = $cont_only +1;    
                    }
                }
            }
            
            if($empresa == 'helena'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='MARIA HELENA'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_helena = $cont_helena +1;    
                    }
                }
            }
            
            if($empresa == 'wjm'){
                if(strtotime($data_mod) >= strtotime($data_inicial) and strtotime($data_mod) <= strtotime($data_final)){
                    if($cartao == $row_row['cartao'] and $row_row['empresa']=='WJM'){
                        $dados = fwrite($normal, "$data  -  $hora_cont  -  $cartao  -  $colaborador $quebra");
                        $cont_wjm = $cont_wjm +1;    
                    }
                }
            }
            
        
        }while(!feof($abrir));
}
            if($empresa == 'cresauto'){
                $dados = fwrite($normal, "$quebra $quebra Total de Refeições ----> $cont_cresauto");
            }
            
                if($empresa == 'asa'){
                $dados = fwrite($normal, "$quebra $quebra Total de Refeições ----> $cont_asa");
            }
            
            if($empresa == 'Brilux'){
                $dados = fwrite($normal, "$quebra $quebra Total de Refeicoes ----> $cont_total");
                
            }
            
            if($empresa == 'ws'){
                $dados = fwrite($normal, "$quebra $quebra Total de Refeicoes ----> $cont_ws");
                
            }
            
            if($empresa == 'nbs'){
                $dados = fwrite($normal, "$quebra $quebra Total de Refeicoes ----> $cont_nbs");
                
            }
            
            if($empresa == 'pm'){
                $dados = fwrite($normal, "$quebra $quebra Total de Refeicoes ----> $cont_pm");
                
            }
            
            //$apaga_frequencia = mysql_query ("DELETE FROM frequencia");
            //$pega = ($apaga_frequencia)or die(mysql_error());
                    

            }else{
                echo "arquivo não encontrado";
        }
            
        //echo $data;
        fclose($abrir);
        fclose($normal);
        
        
        

?>
<br><br>
<p align="center">Relatório Gerado com Sucesso</p>
<p align="center"><a href="<?php echo $arquivo ?>" download>Baixar Arquivo.</a></p>


</script>
</body>
</html>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por ILR master
      Fala galera.
      Espero que todos estejam bem.
      Seguinte: Tenho um arquivo xml onde alguns campos estão com : (dois pontos), como o exemplo abaixo:
       
      <item>
      <title>
      d sa dsad sad sadasdas
      </title>
      <link>
      dsadas dsa sad asd as dsada
      </link>
      <pubDate>sadasdasdsa as</pubDate>
      <dc:creator>
      d sad sad sa ad as das
      </dc:creator>
      </item>
       
      Meu código:
       
      $link = "noticias.xml"; 
      $xml = simplexml_load_file($link); 
      foreach($xml -> channel as $ite) {     
           $titulo = $ite -> item->title;
           $urltitulo = $ite -> item->link;
           print $urltitulo = $ite -> item->dc:creator;
      } //fim do foreach
      ?>
       
      Esse campo dc:creator eu não consigo ler. Como faço?
       
      Agradeço quem puder me ajudar.
       
      Abs
       
       
    • Por First
      Olá a todos!
       
      Eu estou criando um sistema do zero mas estou encontnrando algumas dificuldades e não estou sabendo resolver, então vim recorrer ajuda de vocês.
      Aqui está todo o meu código: https://github.com/PauloJagata/aprendizado/
       
      Eu fiz um sistema de rotas mas só mostra o conteúdo da '/' não sei porque, quando eu tento acessar o register nada muda.
      E eu também quero que se não estiver liberado na rota mostra o erro de 404, mas quando eu tento acessar um link inválido, nada acontece.
      Alguém pode me ajudar com isso? E se tiver algumas sugestão para melhoria do código também estou aceitando.
       
       
      Desde já, obrigado.
    • Por landerbadi
      Olá pessoal, boa tarde
       
      Tenho uma tabela chamada "produtos" com os seguintes campos (id, produto) e outra tabela chamada "itens" com os seguintes campos (id, prod_01, prod_02, prod_03, prod_04).
       
      Na tabela produtos eu tenho cadastrado os seguintes produtos: laranja, maçã, uva, goiaba, arroz, feijão, macarrão, etc.
       
      Na tabela itens eu tenho cadastrado os itens da seguinte maneira:
       
      1, laranja, uva, arroz, feijão;
      2, maçã, macarrão, goiaba, uva;
      3, arroz, feijão, maçã, azeite
       
      Meu problema é o seguinte: 
      Eu escolho um produto da tabela "produtos", por exemplo "uva".  Preciso fazer uma consulta na tabela "itens" para ser listado todos os registros que contenham o produto "uva" e que todos os demais produtos estejam cadastrados na tabela "produtos".
       
      No exemplo acima seria listado apenas dois registros, pois o terceiro registro não contém o produto "uva". 
       
      Alguém pode me ajudar? Pois estou quebrando a cabeça a vários dias e não consigo achar uma solução.
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.