Ir para conteúdo

Arquivado

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

  • 0
moreaux

Dificuldades com manipulação de arrays

Pergunta

Boa tarde, eu estou tendo dificuldades de juntar o valor de um dos meus índices do meu array, caso o valor seja diferente do comparado.

Também estou tendo dificuldades de fazer o meu foreach comparar 1 array com todos e depois pular para o próximo e realizar isso também.


 

<?php


$uploaddir = 'C:\wamp64\www\ ';

$udir = array(' ');
$udir2 = array('');

$replace = str_replace($udir, $udir2, $uploaddir);

$uploadfile = $replace . basename($_FILES['fileToUpload']['name']);


if ($_FILES["fileToUpload"]["error"] > 0)
{
    echo "Error: " . $_FILES["fileToUpload"]["error"] . "<br />";
    }
    else
    {

        $file = fopen("$uploadfile", "r");
/*
        for ($i = 1; $i >10; $i++)
         {
            fwrite($file,"$i php\r\n ");
        }
*/        

        while(! feof($file))
        {
            $line = fgets($file);
            $totalinhas = count($line);


              $linhas_array = array('matriz' => array(explode(",", $line)));    
        
            $total = count($linhas_array);

            print "<pre>";
            //print_r($linhas_array);
            print "<br>";


            $computadores = array();
            $computadorsozinho = array();


            foreach ($linhas_array as $chave => $valor) 
            { 
                
                   if(array_key_exists($chave, $linhas_array)) 
                   {
                    $computadores[$chave] = $linhas_array[$chave];

                } 
                if ($computadores[$chave] == $linhas_array[$chave]) {
                        $computadorsozinho = array_merge($computadores, $linhas_array);
                        $unico = array_unique($computadorsozinho);
                            
                        }        
            }

          print_r($unico);
        }

    
    }

 

 

O resultado desse meu programa é o seguinte 

 

Array

(
    [matriz] => Array
        (
            [0] => Array
                (
                    [0] => COM-17-WIN
                    [1] => Windows
                    [2] => 192.168.2.230
                    [3] => ESET Endpoint Security 6.4.2014.2
                    [4] => 00330-80000-00000-AA042
                    [5] => L1BMDAD

                )

        )

)

Array 
(
  [matriz] => Array 
    ( 
       [0] => Array 
                  (
                      [0] => COM-17-WIN
                      [1] => Windows 
                      [2] => 192.168.2.230
                      [3] => Windows Defender
                      [4] => 00330-80000-00000-AA042 
                      [5] => L1BMDAD
       )
    )
 )
 

 

Se vocês olharem os meus índices tem quase o mesmo valor, apenas o [3] não contém o mesmo valor, eu gostaria de conseguir unir os índices que não tem o mesmo valor e deixar apenas uma vez os valores que já são iguais. 

 

 

Array
(
[matriz] => Array
(
[0] => Array
  (
[0] => COM-17-WIN
[1] => Windows
[2] => 192.168.2.230
[3] => Windows Defender
[4] => 00330-80000-00000-AA042, ESET Endpoint Security 6.4.2014.2
[5] => L1BMDAD
)
)
)

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

1 resposta a esta questão

Recommended Posts

Amigo,

 

Não sei se vou acertar o que você precisa, mas:

 

No caso você tem uma array, dentro uma array dentro de uma array, você tem q passar duas vezes pelos dados pra pegar os valores das 3 camadas, segue um exemplo que acabei de fazer abaixo:

 

//Criando uma array igual a sua
$array = Array(
);

$array['matriz'] = Array(
    "0" => 'Array'
);

$array['matriz'][0] = Array(
    "0" => 'dado 1',
    "1" => 'dado 2',
    "2" => 'dado 3'
);

$array['matriz'][1] = Array(
    "0" => 'dado 4',
    "1" => 'dado 5',
    "2" => 'dado 6'
);
//definindo 0 para a chave
$key_1 = 0;
//parrando o parametro para pegar os valores inclusos na array primaria
foreach ($array as $array_2) {
    //Aqui parra a array primaria com uma key, pois ela pode possuir mais de um elemento
    foreach ($array_2[$key_1] as $array_3[$key_1]) {
        //aqui cada dado da array ja vem separado
        echo $array_3[$key_1];
    }
    //contador de keys
    $key_1 ++;
}

Com os dados certos você consegue fazer o que tem que ser feito.

 

Não cheguei a testar, mas o echo é pra trazer os dados finais.

 

Citar

EDITADO DAQUI PRA BAIXO AQUI - @moreaux acho que essa resposta agr é o que você precisa.

 

Acabou coincidindo de eu ter que fazer algo parecido no meu trabalho hoje: "colocar dados de uma array, dentro de outra array se determinado valor for igual", então ta aí como foi feito:

 

A primeira Array:

Array
(
    [0] => Array
        (
            [id] => 1
            [cod] => COD 1
            [nome] => EMPRESA 1
            [cnpj] => CNPJ 1
            [insc_estadual] => INSC 1
            [tributacao] => SIMPLES NACIONAL
        )

    [1] => Array
        (
            [id] => 2
            [cod] => COD 2
            [nome] => EMPRESA 2
            [cnpj] => CNPJ 2
            [insc_estadual] => INSC 2
            [tributacao] => SIMPLES NACIONAL
        )

)

A segunda Array:

 

Array
(
    [0] => Array
        (
            [id] => 1
            [cod] => codigo 1
            [empresa] => COD 1 // Aqui é que precisa relacionar
            [triagem_notas_ent] => 0
            [triagem_notas_ent_data] => 
            [triagem_notas_saida] => 0
            [triagem_notas_saida_data] => 
            [apuracao] => 1
            [recibo_simples] => 11111111
            [data_envio] => S/M
            [data_confirmacao] => S/M
            [responsavel] => 
            [sintegra] => 2
            [difal_destda] => 3
            [retencoes_cpom] => 1
            [sped_fiscal] => 0
            [sped_contrib] => 0
            [dctf] => 0
            [retencoes] => 0
            [pgdas] => 1
            [mes_correspondente] => 03
            [ano_correspondente] => 2017
            [autor_edicao] => 0
        )
    [1] => Array
        (
            [id] => 2
            [cod] => codigo 2
            [empresa] => COD 2 // Aqui é que precisa relacionar
            [triagem_notas_ent] => 0
            [triagem_notas_ent_data] => 
            [triagem_notas_saida] => 0
            [triagem_notas_saida_data] => 
            [apuracao] => 1
            [recibo_simples] => 11111111
            [data_envio] => S/M
            [data_confirmacao] => S/M
            [responsavel] => 
            [sintegra] => 2
            [difal_destda] => 3
            [retencoes_cpom] => 1
            [sped_fiscal] => 0
            [sped_contrib] => 0
            [dctf] => 0
            [retencoes] => 0
            [pgdas] => 1
            [mes_correspondente] => 03
            [ano_correspondente] => 2017
            [autor_edicao] => 0
        )
)

E aqui p código que coloca uma array dentro da outra.

 

<?php 
//contador				
$i = 0;
//Abro a array $emps          
foreach ($emps as $emps_loop) {
                    // o key $i serve pra dizer com qual array estamos trabalhando
                    $emps_data[$i]['id'] = $emps_loop['id'];
                    $emps_data[$i]['cod'] = $emps_loop['cod'];
                    $emps_data[$i]['nome'] = $emps_loop['nome'];
                    $emps_data[$i]['cnpj'] = $emps_loop['cnpj'];
                    $emps_data[$i]['insc_estadual'] = $emps_loop['insc_estadual'];
                    $emps_data[$i]['grupo_easy'] = $emps_loop['grupo_easy'];
                    $emps_data[$i]['tributacao'] = $emps_loop['tributacao'];
                	//Aqui é aberta a segunda array, repare q essa array foi aberta dentro da outra, assim consigo relacionar dados
                    foreach ($controles as $controle) {
                        //Busco dentro da segunda array ($controles) o dado 'empresa' que é o dado que precisa bater com '$cod' da empresa da primeira array, se igual, salva os dados
                        $cod = $controle['empresa'];
                        if($emps_data[$i]['cod'] == $cod){
                            $emps_data[$i]['controles'] = Array(
                            "pgdas" => $i,
                            "apuracao" => $controle['apuracao'],
                            "recibo_simples" => $controle['recibo_simples'],
                            "controle_cod" => $controle['cod'],
                            "data_envio" => $controle['data_envio'],
                            "data_confirmacao" => $controle['data_confirmacao'],
                            "entrada_notas" => $controle['triagem_notas_ent'],
                            "saida_notas" => $controle['triagem_notas_saida'],
                            "sintegra" => $controle['sintegra'],
                            "difal_destda" => $controle['difal_destda'],
                            "retencoes_cpom" => $controle['retencoes_cpom'],
                            "sped_fiscal" => $controle['sped_fiscal'],
                            "sped_contrib" => $controle['sped_contrib'],
                            "dctf" => $controle['dctf'],
                            "retencoes" => $controle['retencoes'],
                            "pgdas" => $controle['pgdas']
                        );
                        }                        
                    }
  //Impressão para teste
                   echo $emps_data[$i]['id'] . "-" . $emps_data[$i]['controles']['recibo_simples']."<br>";
                    $i++;
                }

Espero ter ajudado!

 

Vlw

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por landerbadi
      Boa tarde pessoal. Estou tentado fazer uma consulta no banco de dados porém estou tendo dificuldades. Tenho uma tabela chamada "itens" com os seguintes campos: id, item, ativo. Nela tem cadastrado vários itens. No campo ativo eu coloco a letra "S" para informar que este item está ativo no sistema. Por exemplo: 1, casa, S 2, mesa, S 3, cama, S 4, moto S 5, rádio O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "produtos" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, mesa, moto 2, mesa, casa, cama 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela produtos da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "mesa". Preciso fazer com que o php me liste todos os registros da tabela "produtos" que contenham a palavra "mesa". Até aqui tudo bem eu consigo listar. Estou fazendo assim: <?php $item = "mesa" $sql = mysqli_query($conn, "SELECT * FROM produtos WHERE item1 LIKE '$item' OR item2 LIKE '$item' OR item3 LIKE '$item' LIMIT 10"); while($aux = mysqli_fetch_assoc($sql)) { $id = $aux["id"]; $item1 = $aux["item1"]; $item2 = $aux["item2"]; $item3 = $aux["item3"]; echo $id . " - " . $item1 . ", " . $item2 . ", " $item3 . "<br>"; } ?> O problema é que está listando todos os registros que contém o item mesa. Eu preciso que o php verifique os demais item e me liste somente os registro em que todos os registros estejam ativos no sistema. No exemplo acima ele não deveria listar o registro 3. pois nesse registro contém o item "radio" e este item não está ativo no sistema. Ou seja, o registro "radio" na tabela itens não possui um "S" na coluna "ativo". Alguém sabe como resolver isso?
    • 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.
    • Por landerbadi
      Boa tarde pessoal. Estou tentado fazer uma consulta no banco de dados porém estou tendo dificuldades. Tenho uma tabela chamada "itens" com os seguintes campos: id, item, plural, ativo. Nela tem cadastrado vários itens e seu respectivo plural. No campo ativo eu coloco a letra "S" para informar que esta palavra está ativa no sistema. Por exemplo: 1, casa, casas, S 2, mesa, mesas, S 3, cama, camas, S 4, moto, motos, S 5, rádio, rádios O quinto registro "radio" não está ativo no sistema pois não tem um "S" no campo ativo. E outra tabela chamada "variações" com os seguintes campos (id, item1, item2, item3) com os seguintes registros: 1, casa, camas, moto 2, mesas, casas, radio 3, rádio, cama, mesa Eu preciso fazer uma busca na tabela variações da seguinte maneira: Eu escolho um registro na tabela "itens", por exemplo "casa". Preciso fazer com que o php me liste todos os registros da tabela "variações" que contenham a palavra "casa". Porém se tiver algum registro com a palavra "casas" também tem que ser listado. Neste caso ele irá encontrar dois registros. Agora eu preciso que o php verifique os demais itens e faça a listagem apenas dos item que estão ativos (que contenham um "S" no campo ativo. Neste caso ele irá encontrar apenas um registro, pois o segundo registro contém a palavra "rádio". E "rádio" não está ativo na tabela itens. Como faço isso?
×

Informação importante

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