Ir para conteúdo
Cintia_Ribeiro

Pesquisar dados dentro de um array

Recommended Posts

Tenho o seguinte array:

array (size=28)
  0 => 
    array (size=5)
      'nome' => string 'Acre' (length=4)
      'sigla' => string 'AC' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 1
  1 => 
    array (size=5)
      'nome' => string 'Alagoas' (length=7)
      'sigla' => string 'AL' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 2
  2 => 
    array (size=5)
      'nome' => string 'Amapá' (length=6)
      'sigla' => string 'AP' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 3
  3 => 
    array (size=5)
      'nome' => string 'Amazonas' (length=8)
      'sigla' => string 'AM' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 4
  4 => 
    array (size=5)
      'nome' => string 'Bahia' (length=5)
      'sigla' => string 'BA' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 5
  5 => 
    array (size=5)
      'nome' => string 'Ceará' (length=6)
      'sigla' => string 'CE' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 6
  6 => 
    array (size=5)
      'nome' => string 'Distrito Federal' (length=16)
      'sigla' => string 'DF' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 7
  7 => 
    array (size=5)
      'nome' => string 'Espírito Santo' (length=15)
      'sigla' => string 'ES' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 8
  8 => 
    array (size=5)
      'nome' => string 'Goiás' (length=6)
      'sigla' => string 'GO' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 9
  9 => 
    array (size=5)
      'nome' => string 'Maranhão' (length=9)
      'sigla' => string 'MA' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 10
  10 => 
    array (size=5)
      'nome' => string 'Mato Grosso' (length=11)
      'sigla' => string 'MT' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 11
  11 => 
    array (size=5)
      'nome' => string 'Mato Grosso do Sul' (length=18)
      'sigla' => string 'MS' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 12
  12 => 
    array (size=5)
      'nome' => string 'Minas Gerais' (length=12)
      'sigla' => string 'MG' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 13
  13 => 
    array (size=5)
      'nome' => string 'Pará' (length=5)
      'sigla' => string 'PA' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 14
  14 => 
    array (size=5)
      'nome' => string 'Paraíba' (length=8)
      'sigla' => string 'PB' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 15
  15 => 
    array (size=5)
      'nome' => string 'Paraná' (length=7)
      'sigla' => string 'PR' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 16
  16 => 
    array (size=5)
      'nome' => string 'Pernambuco' (length=10)
      'sigla' => string 'PE' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 17
  17 => 
    array (size=5)
      'nome' => string 'Piauí' (length=6)
      'sigla' => string 'PI' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 18
  18 => 
    array (size=5)
      'nome' => string 'Rio de Janeiro' (length=14)
      'sigla' => string 'RJ' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 19
  19 => 
    array (size=5)
      'nome' => string 'Rio Grande do Norte' (length=19)
      'sigla' => string 'RN' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 20
  20 => 
    array (size=5)
      'nome' => string 'Rio Grande do Sul' (length=17)
      'sigla' => string 'RS' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 21
  21 => 
    array (size=5)
      'nome' => string 'Rondônia' (length=9)
      'sigla' => string 'RO' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 22
  22 => 
    array (size=5)
      'nome' => string 'Roraima' (length=7)
      'sigla' => string 'RR' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 23
  23 => 
    array (size=5)
      'nome' => string 'Santa Catarina' (length=14)
      'sigla' => string 'SC' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 24
  24 => 
    array (size=5)
      'nome' => string 'São Paulo' (length=10)
      'sigla' => string 'SP' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 25
  25 => 
    array (size=5)
      'nome' => string 'Sergipe' (length=7)
      'sigla' => string 'SE' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 26
  26 => 
    array (size=5)
      'nome' => string 'Tocantins' (length=9)
      'sigla' => string 'TO' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 27
  27 => 
    array (size=5)
      'nome' => string 'Superiores' (length=10)
      'sigla' => string 'BR' (length=2)
      'paisId' => int 0
      'pais' => null
      'id' => int 28

Preciso pesquisar dentro dele o id de uma determinada siga. Ex.: Preciso fazer uma pesquisa onde eu passe como parâmetro "RJ" e ele me retorna 19

Compartilhar este post


Link para o post
Compartilhar em outros sites
<?php
function getIdPorSigla( $array, $sigla ) {
    $sigla_maiuscula = mb_strtoupper( $sigla );
    
    foreach ( $array as $item )
        if ( mb_strtoupper( $item[ 'sigla' ] ) === $sigla_maiuscula )
            return (int)$item[ 'id' ];
    
    return null;//ou uma exception...
}

echo getIdPorSigla( $meu_array, 'RJ' ) ?: 'Sigla não encontrada.';

 

A conversão para maiúsculas é apenas uma garantia adicional para caso um dos itens no array ou a sigla buscada esteja "rj" ao invés de "RJ", por ex.

 

Caso não tenha entendido alguma coisa na sintaxe/algoritmo, me diga que eu explico... Não use o código sem entender sua lógica.

 

Obs: não sei exatamente qual versão do PHP é a mínima pra rodar esse script, pq usei recursos meio recentes da linguagem, mas se der erro você posta e ajudamos a modificar.

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 dba.amaro
      Galera, bom dia/tarde/noite, 
       
      Estou desenvolvendo uma aplicação web, porém preciso mostrar algumas informações e os objetos vão mudar de cor / porcentagem, segundo as informações que estão contidas no banco de dados, 
       
      Tenho, algumas ideias, porém não sei nem por onde começar, se alguém puder ajudar, agradeço !!
       
      Um abraço  a todos e bons posts!
    • Por Malebo
      Boas.
       
      Estou a três semana com erro abaixo, preciso da vossa ajura para poder baixar as imagens do mysql no laradock.
      Abaixo o trecho de codigo, quando executou docker-compose up -d mysql ele nunca sai desta tela.
       
      $ docker-compose build --no-cache mysql
      Building mysql
      Step 1/9 : ARG MYSQL_VERSION=8.0
      Step 2/9 : FROM mysql:${MYSQL_VERSION}
      8.0: Pulling from library/mysql
       
    • Por zinleo1
      Estou precisando consultar o endereço(tipo_logradouro e logradouro) de um cliente no meu banco de dados mas to tendo problemas no select, alguém consegue me ajudar, como faço para dar select em duas tabelas? Segue o código:
       
       

      <html>
          <head>
              <meta charset="UTF-8">
              <title></title>
          </head>
          <body>
      <fieldset>
      <legend>Lista de Registros</legend>
      <table border="1" width="100%">
       <tr>
            <th>Código do Usuário</th>
            <th>Nome do Usuário</th>
            <th>Sobrenome do Usuário</th>
            <th>Tipo de Logradouro</th>
            <th>Logradouro</th>
       </tr>
       
      <?php
          
          if(isset($_POST["consultar"])){
                  $nome = $_POST['nome'];
                  $sobrenome = $_POST['sobrenome'];
                  
                          
                 
               include('conexao.php');
          
                  $sqlconsultaraluno= "select * from aluno where nome_aluno='$nome' or sobrenome_aluno='$sobrenome'"; 
                  $consultaraluno = mysqli_query($con,$sqlconsultaraluno);
                              
                 $i = 0;
              if (mysqli_num_rows($consultaraluno, $consultarendereco) == 0){
                  echo "<h4>Nenhum Registro Encontrado!</h4>";
              }
              else{
              while ($linha = mysqli_fetch_array($consultarendereco)) {
                 $cod_aluno = $linha["cod_aluno"];
                 $nome = $linha["nome_aluno"];
                 $sobrenome = $linha["sobrenome_aluno"];
                         $tipologradouro = $linha['tipo_logradouro'];
                         $logradouro = $linha ['logradouro'];    
                         
                 if ($i % 2 == 0){
                    $cor = "#DDDDDD";
                 }
                 else{
                    $cor = "#FFFFFF";
                 }
                         
                 
          ?>
              <tr bgcolor="<?php echo $cor; ?>"
                          <td></td>
                          <td><?php echo $cod_aluno; ?></td>
                          <td><?php echo $nome; ?></td>
                          <td><?php echo $sobrenome; ?></td>
                          <td><?php echo $tipologradouro; ?></td>
                          <td><?php echo $logradouro; ?></td>
                          
                         
                          <td><?php echo "<a href='editar_usuario.php?id=".$linha["cod_aluno"]."'>Editar</a>";?></td>
                          <td><?php echo "<a href='deletar_usuario.php?id=".$linha["cod_aluno"]."'>Deletar</a>";?></td>
              </tr>
               
              <?php
                 $i++;
                         
              }
          }
        
              }
                      
      ?>
      </table>
          </body>
      </html>
    • Por diogoglobaltec
      criei um formulário dinamico e gostaria de enviar para o arquivo rec.php, os aquivos adicionados pelo no formato file , já tentei colocar em
       x.setAttribute("enctype" , "multipart/form-data");
      também não funcionou segue o arquivo:
       
      <!DOCTYPE html>
          <html>
              <body>
              
                  
                  
                  <p>Click the button to create a FORM and an INPUT element.</p>
                  <button onclick="myFunction()">Try it</button>
                  <button onclick="enviar()">enviar</button>
          <script>
          function myFunction() {
            var x = document.createElement("FORM");
            x.setAttribute("action", "rec.php");
          x.setAttribute("method", "post");
          x.setAttribute("id", "myForm");
            document.body.appendChild(x);

            var y = document.createElement("INPUT");
            y.setAttribute("type", "file");
            y.setAttribute("name", "arquivo[]");
            document.getElementById("myForm").appendChild(y);
      }
           function enviar(){
              document.forms[0].submit(); 
          
          }
          </script>

              </body>
      </html>
       
      consigo pegar no arquivo rec.php o valor de $_POST , mas de $_FILES não consigo pegar como um array, o que está dando errado ? segue o  script PHP 
       
      Arquivo rec.php
      <?php
      foreach($_POST['arquivo'] as $value) {
              echo $value."<br />";
      }
      foreach($_FILES['arquivo'] as $value) {
                     echo $value['arquivo']['name']."<br />";
      }
       
       
       
       
    • Por Jonas Ribeiro Nascimento
      Estou criando meu próprio mvc php para adquirir mais conhecimento.
      Mas estou me deparando com uma coisa muita estranha, eu perco a $_SESSION de uma view para outra view
      Fiz um codigo simples pra testar.a.php ----- view a.php
      <?php session_start(); $_SESSION['teste'] = 'Funcionou'; echo $_SESSION['teste']; ?> <?php session_start(); echo $_SESSION['teste']; // Notice: Undefined variable: _SESSION in var_dump($_SESSION); // Notice: Undefined variable: _SESSION in NULL ?> <?php namespace Sis\Classes; use App\Model\ClassLogin; use Sis\Traits\TraitGetIp; class ClassSession { private $login; private $timeSession = 1200; private $timeCanary = 300; public function __construct(){ if(session_id() == ''){ ini_set("session.save_handler", "files"); //Cabeçalhos somente atraves de arquivos ini_set("session.use_cookies", 1); //Habilita o uso de cookies ini_set("session.use_only_cookies", 1); //Só pode habilitar a seção atraves de coockies ini_set("session.cookie_domain", DOMAIN); //Só aceita coockies vindo do nosso sistema ini_set("session.cookie_httponly", 1); //Só aceita script php e não deixa o javascript alterar o sistema if(DOMAIN != "localhost"){ ini_set("session.cookie_secure", 1); //Para trabalhar com o SSL do servidor ativo } /*Criptografia das nossas sessions*/ ini_set("session.entropy_length", 512); // ini_set("session.entropy_file","/dev/urandom"); ini_set("session.hash_function", "sha256"); ini_set("session.hash_bits_per_character", 5); session_start(); } $this->login = new ClassLogin(); } #Proteger contra roubo de sessão public function setSessionCanary($par=null){ session_regenerate_id(true); if($par == null){ $_SESSION['canary']=[ "birth" => time(), "IP" => TraitGetIp::getUserIp() //Pega o ip do usuario ]; }else{ $_SESSION['canary']['birth']=time(); } } #Verificar a integridade da sessão public function verifyIdSessions(){ if(!isset($_SESSION['canary'])){ $this->setSessionCanary(); } if($_SESSION['canary']['IP'] !== TraitGetIp::getUserIp()){ $this->destructSessions(); $this->setSessionCanary(); } if($_SESSION['canary']['birth'] < time() - $this->timeCanary){ $this->setSessionCanary("Time"); } } #Setar as sessões do nosso sistema public function setSessions($Email){ $this->verifyIdSessions(); $_SESSION['Login'] = true; $_SESSION['Time'] = time(); $_SESSION['Nome'] = $this->login->getIssetSession($Email)['data']['Nome']; $_SESSION['Email'] = $this->login->getIssetSession($Email)['data']['Email']; $_SESSION['Permissoes'] = $this->login->getIssetSession($Email)['data']['Permissoes']; } #Validar as páginas internas do sistema public function verifyInsideSession(){ $this->verifyIdSessions(); if(!isset($_SESSION['Login']) || !isset($_SESSION['Permissoes']) || !isset($_SESSION['canary'])){ $this->destructSessions(); header("Location: ".DIRPAGE."NaoAutorizado"); }else{ if($_SESSION['Time'] >= time() - $this->timeSession){ $_SESSION['Time']=time(); }else{ $this->destructSessions(); header("Location: ".DIRPAGE."NaoAutorizado"); } } } #Destruir as sessions existentes public function destructSessions(){ foreach (array_keys($_SESSION) as $key) { unset($_SESSION[$key]); } } #testar public function testarSessions(){ echo 'oiiiiiiiiiiiiiiiiiiiiiiooooooooooo'; } }

×

Informação importante

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