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, me permita tirar uma dúvida com os amigos.

      Tenho um Formulário onde o Usuário digita todos os Dados necessários.

      Minha dúvida:
      --> como faço após o usuário digitar os dados e salvar, o Sistema chamar uma Modal ou mensagem perguntando se deseja imprimir agora ?

      Grato,
       
      Cesar
    • Por Carcleo
      Tenho uma abela de usuarios e uma tabela de administradores e clientes.
      Gostaria de uma ajuda para implementar um cadastro
       
      users -> name, login, passord (pronta) admins -> user_id, registratiom, etc.. client -> user_id, registratiom, etc...
      Queria ajuda para extender de user as classes Admin e Client
      Olhem como estáAdmin
      <?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; class Admin extends User {     use HasFactory;            protected $fillable = [         'name',         'email',         'password',         'registration'     ];      private string $registration;     public function create(         string $name,          string $email,          string $password,         string $registration     )     {         //parent::create(['name'=>$name, 'email'=>$email, 'password'=>$password]);         parent::$name = $name;         parent::$email = $email;         parent::$password = $password;         $this->registration = $registration;     } } User
      <?php namespace App\Models; // use Illuminate\Contracts\Auth\MustVerifyEmail; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; use Illuminate\Database\Eloquent\Relations\BelongsToMany; class User extends Authenticatable {     /** @use HasFactory<\Database\Factories\UserFactory> */     use HasFactory, Notifiable;     static string $name;     static string $email;     static string $password;     /**      * The attributes that are mass assignable.      *      * @var list<string>      */     protected $fillable = [         'name',         'email',         'password',     ];          /**      * The attributes that should be hidden for serialization.      *      * @var list<string>      */     protected $hidden = [         'remember_token',     ];     /**      * Get the attributes that should be cast.      *      * @return array<string, string>      */     protected function casts(): array     {         return [             'email_verified_at' => 'datetime',             'password' => 'hashed',         ];     }          public function roles() : BelongsToMany {         return $this->belongsToMany(Role::class);     }       public function hasHole(Array $roleName): bool     {                 foreach ($this->roles as $role) {             if ($role->name === $roleName) {                 return true;             }         }         return false;     }         public function hasHoles(Array $rolesName): bool     {                 foreach ($this->roles as $role) {             foreach ($rolesName as $rolee) {             if ($role->name === $rolee) {                 return true;             }          }         }         return false;     }         public function hasAbility(string $ability): bool     {         foreach ($this->roles as $role) {             if ($role->abilities->contains('name', $ability)) {                 return true;             }         }         return false;     }     } Como gravar um Admin na tabela admins sendo que ele é um User por extensão?
      Tentei assim mas é claro que está errado...
      public function store(Request $request, Admin $adminModel) {         $dados = $request->validate([             "name" => "required",             "email" => "required|email",             "password" => "required",             "registration" => "required"         ]);         $dados["password"] =  Hash::make($dados["password"]);                  $admin = Admin::where("registration",  $dados["registration"])->first();                  if ($admin)              return                    redirect()->route("admin.new")                             ->withErrors([                                 'fail' => 'Administrador já cadastrados<br>, favor verificar!'                   ]);                            $newAdmin = $adminModel->create(                                    $dados['name'],                                    $dados['email'],                                    $dados['password'],                                    $dados['registration']                                 );         dd($newAdmin);         $adminModel->save();         //$adminModel::create($admin);                  return redirect()->route("admin.new")->with("success",'Cadastrado com sucesso');     }  
    • Por violin101
      Caros amigos, saudações.
       
      Gostaria de tirar uma dúvida com os amigos, referente a PDV.
       
      Estou escrevendo um Sistema com Ponto de Vendas, a minha dúvida é o seguinte, referente ao procedimento mais correto.

      Conforme o caixa vai efetuando a venda, o Sistema de PDV já realiza:
      a baixa direto dos produtos no estoque
      ou
      somente após concretizar a venda o sistema baixa os produtos do estoque ?
       
      Grato,
       
      Cesar
       
    • Por violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • 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
×

Informação importante

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