Ir para conteúdo
Supershopping

Arrays multidimensionais em php

Recommended Posts

Galera, me ajudem, alguem consegue me expliocar o que está acontecendo nessa parte do código??

Pelo menos o primeiro for com row==0.Que tipo de conta seria?? (alguns dados foram declarados antes, caso precisarem é so comentar)

Como estou analisando gostaria de saber que tipo de conta devo fazer para chegar no mesmo resultado do programa. Agradço desde já!

 

     
    //Fluxo
    //-------gerar array multidimensional com valores base do payback 
     //Ano Índice    kW/Ano/Wp   Energia Gerada (kWh)    Retorno Financ. 1   Custos Anuais   SubTotal    Fluxo Final
    $arrFluxo = array();

    for ($row = 0; $row < 25; $row++) {

        if($row == 0){
            $porcFatorPerdas = porcentagem($array['potenciaSistema'],$fatorPerdas);
            $porcDegracaoPaineis = porcentagem($porcFatorPerdas,$degradacaoPaineisAno1);
            $energiaGerada = ($porcDegracaoPaineis*($wattsPicoMedioAno/1000));
            
            $retornoFinanciamento = ($energiaGerada*$valorEnergia);
            
            $porcCustoManutencao = ($custoManutencaoAno/2);
            $custosAnuais = -$array['valorInicial']+porcentagem(-$array['valorInicial'],$porcCustoManutencao);
            
            $SubTotal = ($custosAnuais+$retornoFinanciamento);
            $fluxoFinal = '';

            array_push($arrFluxo,array($row,$wattsPicoMedioAno,$energiaGerada,$retornoFinanciamento,$custosAnuais,$SubTotal,$fluxoFinal));
        }else{         

            $porcFatorPerdas = porcentagem($array['potenciaSistema'],$fatorPerdas);//OK
            $porcDegracaoPaineis = porcentagem($porcFatorPerdas,pow4($degradacaoPaineisDemaisAnos,$row));
            $energiaGerada = porcentagem($porcDegracaoPaineis*($wattsPicoMedioAno/1000),$degradacaoPaineisAno1);
                      
            $porcInflacao = pow3($inflacaoEnergeticaProjetada,$row);          
            $retornoFinanciamento = porcentagem(($energiaGerada*$valorEnergia),$porcInflacao);
                 
            //=-$G$51*($G$43*((1+$G$52)^B65))+SE($G$54=B65;-$G$55;0) fazer custos anuais
            $custosAnuaisInflacao = porcentagem($array['valorInicial'],pow3($inflacaoProjetada,$row));
            $custosAnuais = -(porcentagem2($custosAnuaisInflacao,$custoManutencaoAno)-$custosAnuaisInflacao);
            if($anoTrocaInversor == $row){
                $custosAnuais += -$custoInversorNaTroca;
            }

            $SubTotal = ($custosAnuais+$retornoFinanciamento);
            if($row==1){
                $fluxoFinal = $arrFluxo[$row-1][5]+$SubTotal;
            }
            else{
                $fluxoFinal = $arrFluxo[$row-1][6]+$SubTotal;
            }
            
            array_push($arrFluxo,array($row,$wattsPicoMedioAno,$energiaGerada,$retornoFinanciamento,$custosAnuais,$SubTotal,$fluxoFinal));
        }
    }
 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar Agora

  • Conteúdo Similar

    • Por ILR master
      Boa tarde, pessoal.
      Espero que todos estejam bem.
       
      Seguinte:
      Tenho a seguinte consulta:
       
      $usuarios= "SELECT * FROM usuarios";
      $query= mysqli_query($conexao, $usuarios) or die ("Usuário não encontrado");
      $usuario = mysqli_fetch_array($query);
       
      Quero pegar apenas o campo 'nome' da tabela 'usuarios' e colocar todos os resultados da seguinte forma:
       
      $nomes = array("Rafael", "João", "Maria", "Pedro", "Patricia", "Camila");
       
      Agradeço desde já.
      Abs
       
       
    • Por mateus.andriollo
      Existe uma forma de fazer um IF na select e comparar com Array de dados?
       
      algo como
       
      Select if( in_array(idCliente,'1,2,3,4,5')=true,'Tem','Não') ) as cliente Não consigo usar inner ou where pois esse array é algo q tem varias regras...
       
      Precisava saber se existe uma função assim em MySQL
    • Por mateus.andriollo
      Existe uma forma de fazer um IF na select e comparar com Array de dados?
       
      algo como
       
      Select if( in_array(idCliente,'1,2,3,4,5')=true,'Tem','Não') ) as cliente Não consigo usar inner ou where pois esse resultado do array é algo q tem varias regras...
       
      Precisava saber se existe uma função assim em MySQL
    • Por clovis.sardinha
      Bom dia.
      Meu problema é o seguinte:
      Estou fazendo uma tabela e preciso mostrar o usuário e várias cidades que pertencem a este usuário.
      O resultado do array é o seguinte:

      Quando passo para a tabela os valores de cidade se repetem para o mesmo usuário até o final e retorna fazendo o mesmo para o próximo usuário. 
      Veja abaixo

       
      Meu código para a tabela é a seguinte:
      <tr> <td align="left"><?php echo $usuario['nome'] ?></td> <td align="left"><?php echo $usuario['nome_orgao'] ?></td> <td align="left"><?php echo $usuario['nome_funcao'] ?></td> <?php foreach($destinos as $key=>$destino):?> <?php $key=0;?> <td align="left"> <?php foreach($destino as $chave=> &$cidade): ?> <?php echo $cidade['cid_nome']."-";?> <?php endforeach;?> </td> <?php $key+=$key; ?> <?php endforeach;?> <td><?php echo date('d/m/Y', strtotime( $usuario['created_at'])) ?></td> <td align="left"><a href="<?php echo base_url('UserAdmin/Usuario/getUsuarioById')."/".$usuario['id_user'] ?>">DETALHES</a></td> </tr> <?php endforeach ?> Onde estou errando? O que tenho de fazer para percorrer este array de modo a aparecer apenas as cidades pertencentes a cada usuário?

    • Por Giovanird
      Listo um array pelo foreach e preciso pegar os valores fora do foreach.
      Abaixo tenho o exemplo do foreach com os valores
       
      <?php foreach($turma $rsturma): if(($rsturma['id'] == 1){ echo $rsturma['nome']."<br>"; echo $rsturma['idade']."<br><br>"; } endforeach; //Dentro do foreach me retorna: Luis 13 Maria 12 Carlos 12 Matheus 14 Andréa 12 //Preciso pegar a posição e o valor desta lista $posicao1 = 1; $nome1 = Luis; $posicao2 = 2; $nome2 = Maria; $posicao3 = 3; $nome3 = Carlos; $posicao4 = 4; $nome4 = Matheus; $posicao5 = 5; $nome5 = Andréa;  
×

Informação importante

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