Ir para conteúdo

POWERED BY:

Arquivado

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

Guilherme Luiz

Calculo composto de tempo

Recommended Posts

Olá pessoal,

 

Estou precisando fazer um calculo composto de tempo.

Esse calculo terá valores dinâmicos de tempo e quantidade de acordo com o input do usuario. A intenção é fazer uma fracionador de envios de e-mail, onde o usuário vai dizer que quer dividir o total de envios que possui em X partes em Y tempo entre cada uma das partes.

 

Por exemplo:

 

- Total de envios: 200

- Fracionar em: 15 partes

- Tempo entre as partes: 20 minutos

- Inicio: 15h00m

 

Dentro desse cenário eu precisaria gerar uma lista da seguinte forma:

 

parte 01 - 15h00m

parte 02 - 15h20m

parte 03 - 15h40m

parte 04 - 16h00m

parte 05 - 16h20m

...e assim sucessivamente, sempre calculando o tempo de forma composta/progressiva

 

Na matemática simples o calculo seria básico:

Parte * Tempo = X + Inicio (X é o tempo que buscamos para ir adicionando de forma composta de acordo com o numero da parte do envio)

 

Exemplo:

1 * 20 = X + 15h00m -> x = 20 + 15h00m = 15h20m

2 * 20 = X + 15h00m -> x = 40 + 15h00m = 15h40m

3 * 20 = X + 15h00m -> x = 60 + 15h00m = 16h00m

 

Como coloco isso no PHP para ser impresso numa lista, onde a lista precisaria ficar organizada entre as partes sendo demonstrado algo como:

 

 

Envio 01 - Parte 01 - 15h00

Envio 02 - Parte 01 - 15h00

Envio 03 - Parte 01 - 15h00

...

Envio 16 - Parte 02 - 15h20

Envio 17 - Parte 02 - 15h20

Envio 18 - Parte 02 - 15h20

...

Envio 31 - Parte 03 - 15h40

Envio 32 - Parte 03 - 15h40

Envio 33 - Parte 03 - 15h40

 

Vejam, a dúvida é sobre como criar o calculo composto porque a manipulação do tempo frente ao total de minutos que serão adicionados ao tempo inicial isso tenho em mente como fazer.

Alguém consegue dar essa força ou me indicar algum material de leitura para conseguir aplicar essa regra?

Compartilhar este post


Link para o post
Compartilhar em outros sites

@Guilherme Luiz 

 

Bom para criar o calculo do tempo entre os envios de e-mail, você pode fazer usando o método Date do próprio php.

 

Vou deixa a documentação do método Date dá W3 https://www.w3schools.com/php/php_ref_date.asp.

 

Obs..: O método Date também conta com um modelo POO

 

Um exemplo de como usar:

<?php

$data = date_create();

$dados = array(
	"numeroEnvios"=>20, // Numero de e-mail que Serão enviados
	"intervalo"=>"15 minutes", // Intervalo entre os pacotes de envio de e-mail
	"numeroPacotes"=>4 // Numero de pacotes de envio de e-mail
);

$dadosEnvio = array(); // Array com a ordem de envio

$envio = 1;

for ($num = 1; $num < $dados["numeroPacotes"] + 1; $num++)
{
	for($num_2 = 0; $num_2 < ceil($dados["numeroEnvios"] / $dados["numeroPacotes"]); $num_2++)
	{
		if($envio < $dados["numeroEnvios"] + 1)
		{
			$dadosEnvio[$num - 1][$num_2] = array(
				"Id"=>$envio,
				"Id_pacote"=>$num,
				"Data"=>date_format($data,"Y-m-d H:i")	
			);
		}
		else
		{
			break;
		}
		$envio++;
	}
	date_add($data, date_interval_create_from_date_string($dados["intervalo"]));
}

var_dump($dadosEnvio); // retorno

O reporta ficaria assim:

array(4) { 
	[0]=> array(5) { 
		[0]=> array(3) { ["Id"]=> int(1) ["Id_pacote"]=> int(1) ["Data"]=> string(16) "2019-07-08 19:01" } 
		[1]=> array(3) { ["Id"]=> int(2) ["Id_pacote"]=> int(1) ["Data"]=> string(16) "2019-07-08 19:01" } 
		[2]=> array(3) { ["Id"]=> int(3) ["Id_pacote"]=> int(1) ["Data"]=> string(16) "2019-07-08 19:01" } 
		[3]=> array(3) { ["Id"]=> int(4) ["Id_pacote"]=> int(1) ["Data"]=> string(16) "2019-07-08 19:01" } 
		[4]=> array(3) { ["Id"]=> int(5) ["Id_pacote"]=> int(1) ["Data"]=> string(16) "2019-07-08 19:01" } 
	} 
	[1]=> array(5) { 
		[0]=> array(3) { ["Id"]=> int(6) ["Id_pacote"]=> int(2) ["Data"]=> string(16) "2019-07-08 19:16" } 
		[1]=> array(3) { ["Id"]=> int(7) ["Id_pacote"]=> int(2) ["Data"]=> string(16) "2019-07-08 19:16" } 
		[2]=> array(3) { ["Id"]=> int(8) ["Id_pacote"]=> int(2) ["Data"]=> string(16) "2019-07-08 19:16" } 
		[3]=> array(3) { ["Id"]=> int(9) ["Id_pacote"]=> int(2) ["Data"]=> string(16) "2019-07-08 19:16" } 
		[4]=> array(3) { ["Id"]=> int(10) ["Id_pacote"]=> int(2) ["Data"]=> string(16) "2019-07-08 19:16" } 
		} 
	[2]=> array(5) { 
		[0]=> array(3) { ["Id"]=> int(11) ["Id_pacote"]=> int(3) ["Data"]=> string(16) "2019-07-08 19:31" } 
		[1]=> array(3) { ["Id"]=> int(12) ["Id_pacote"]=> int(3) ["Data"]=> string(16) "2019-07-08 19:31" } 
		[2]=> array(3) { ["Id"]=> int(13) ["Id_pacote"]=> int(3) ["Data"]=> string(16) "2019-07-08 19:31" } 
		[3]=> array(3) { ["Id"]=> int(14) ["Id_pacote"]=> int(3) ["Data"]=> string(16) "2019-07-08 19:31" } 
		[4]=> array(3) { ["Id"]=> int(15) ["Id_pacote"]=> int(3) ["Data"]=> string(16) "2019-07-08 19:31" } 
	} 
	[3]=> array(5) { 
		[0]=> array(3) { ["Id"]=> int(16) ["Id_pacote"]=> int(4) ["Data"]=> string(16) "2019-07-08 19:46" } 
		[1]=> array(3) { ["Id"]=> int(17) ["Id_pacote"]=> int(4) ["Data"]=> string(16) "2019-07-08 19:46" } 
		[2]=> array(3) { ["Id"]=> int(18) ["Id_pacote"]=> int(4) ["Data"]=> string(16) "2019-07-08 19:46" } 
		[3]=> array(3) { ["Id"]=> int(19) ["Id_pacote"]=> int(4) ["Data"]=> string(16) "2019-07-08 19:46" } 
		[4]=> array(3) { ["Id"]=> int(20) ["Id_pacote"]=> int(4) ["Data"]=> string(16) "2019-07-08 19:46" } 
	} 
}

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Muito obrigado @gabrielms

 

Ao final utilizando o core do seu código eu cheguei na seguinte função:
 

<?php 

function fractionate($vol,$parts,$interval,$date){
  $initalDate   = date_create($date);
  $intervalList = [];
  $result       = [];
  $limiterList  = 1;
  ##########
  for ($num = 1; $num < $parts + 1; $num++){
    for($num_2 = 0; $num_2 < ceil($vol / $parts); $num_2++)	{
      if($limiterList < $vol + 1){
        $intervalList[$num-1][$num_2] = date_format($initalDate,"Y-m-d H:i:s");
      }else{
        break;
      }
    $limiterList++;
    }
    date_add($initalDate, date_interval_create_from_date_string($interval.' minutes'));
  }
  ##########
  foreach($intervalList as $k){
    foreach($k as $v){
      $result[] = $v;
    }
  }
  return $result;
}

 

Desta forma eu tenho um array com os horários numa lista com a mesma quantidade de indices de um array meu com a lista de e-mails. Desta forma eu crio um agendamento para todos os envios com base na hora de envio do usuário, seja ela imediata ou programada.

 

Muito obrigado!
 

obs: Tentei dar +1 mas o forum está dando erro, logo volto aqui e tento pontuar novamente

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Humildemente peço desculpa por postar uma dúvida que tenho.

      Preciso salvar no MySql, os seguinte Registro:

      1 - Principal
      ====> minha dúvida começa aqui
      ==========> como faço para o Sistema Contar Automaticamente o que estiver despois do 1.____?
      1.01 - Matriz
      1.01.0001 - Estoque
      1.01.0002 - Oficina
      etc

      2 - Secundário
      2.01 - Loja_1
      2.01.0001 - Caixa
      2.01.0002 - Recepção
      etc
       
      Resumindo seria como se fosse um Cadastro de PLANO de CONTAS CONTÁBEIL.

      Grato,


      Cesar









       
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a orientação dos amigos.

      Preciso fazer um Relatório onde o usuário pode Gerar uma Lista com prazo para vencimento de: 15 / 20/ 30 dias da data atual.

      Tem como montar uma SQL para o sistema fazer uma busca no MySql por período ou dias próximo ao vencimento ?

      Tentei fazer assim, mas o SQL me traz tudo:
      $query = "SELECT faturamento.*, DATE_ADD(faturamento.dataVencimento, INTERVAL 30 DAY), fornecedor.* FROM faturamento INNER JOIN fornecedor ON fornecedor.idfornecedor = faturamento.id_fornecedor WHERE faturamento.statusFatur = 1 ORDER BY faturamento.idFaturamento $ordenar ";  
      Grato,
       
      Cesar
       
       
       
       
    • Por violin101
      Caros amigos, saudações
       
      Por favor, me perdoa em recorrer a orientação dos amigos, tenho uma dúvida.
       
      Gostaria de uma rotina onde o Sistema possa acusar para o usuário antes dos 30 dias, grifar na Tabela o aviso de vencimento próximo, por exemplo:
       
      Data Atual: 15/11/2024
                                           Vencimento
      Fornecedor.....................Data.....................Valor
      Fornecedor_1...........01/12/2024..........R$ 120,00 <== grifar a linha de Laranja
      Fornecedor_1...........01/01/2025..........R$ 130,00
      Fornecedor_2...........15/12/2024..........R$ 200,00 <== grifar a linha de Amarelo
      Fornecedor_2...........15/01/2025..........R$ 230,00
      Fornecedor_3...........20/12/2024..........R$ 150,00
       
      Alguém tem alguma dica ou leitura sobre este assunto ?

      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a ajuda dos amigos, mas preciso entender uma processo que não estou conseguindo sucesso.

      Como mencionado no Título estou escrevendo um Sistema Web para Gerenciamento de Empresa.
       
      Minha dúvida, que preciso muito entender:
      - preciso agora escrever a Rotina para Emissão de NFe e essa parte não estou conseguindo.
       
      tenho assistido alguns vídeos e leituras, mas não estou conseguindo sucesso, já fiz toda as importações das LIB da NFePhp conforme orientação.

      Preciso de ajuda.

      Algum dos amigos tem conhecimento de algum passo-a-passo explicando a criação dessa rotina ?

      tenho visto alguns vídeos com LARAVEL, mas quando tento utilizar e converter para PHP+Codeiginter, dá uma fila de erros que não entendo, mesmo informando as lib necessárias.

      Alguns do amigo tem algum vídeo, leitura explicando essa parte ?

      Grato,

      Cesar.
×

Informação importante

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