Foros del Web » Programando para Internet » PHP »

Como comparar varias columnas almacenadas en un array.

Estas en el tema de Como comparar varias columnas almacenadas en un array. en el foro de PHP en Foros del Web. Buenas tardes compañeros, Voy al grano porque tengo delante un problema que me está volviendo loco y no creo que sea de difícil solución. Pero ...
  #1 (permalink)  
Antiguo 27/02/2015, 03:59
 
Fecha de Ingreso: agosto-2009
Mensajes: 91
Antigüedad: 15 años, 3 meses
Puntos: 2
Como comparar varias columnas almacenadas en un array.

Buenas tardes compañeros,

Voy al grano porque tengo delante un problema que me está volviendo loco y no creo que sea de difícil solución. Pero no la veo

Tengo almacenado en un array un conjunto de filas, para poneros en situación os pongo lo que muestra por pantalla un echo de cada posición de ese array:

echo $nodup_filter[0];


Código HTML:
<tr>
<td>29/06/2015</td>
<td>09:00</td>
<td>29/06/2015</td>
<td>12:00</td>
<td>3</td>
<td>code 1</td>
<td>1007 Additional information 5</td>
<td>109 Additional information 6</td>
<td>Additional information 7</td>
<td>Additional information 8</td>
<td> </td>
</tr> 

echo $nodup_filter[1];


Código HTML:
<tr>
<td>12/02/2015</td>
<td>16:00</td>
<td>14/04/2015</td>
<td>18:00</td>
<td>2</td>
<td>Code 2</td>
<td>Additional information 1</td>
<td>Additional information 2</td>
<td>Additional information 3</td>
<td>Additional information 4</td>
<td> </td>
</tr> 



echo $nodup_filter[2];


Código HTML:
 <tr>
<td>29/06/2015</td>
<td>09:00</td>
<td>29/06/2015</td>
<td>12:00</td>
<td>3</td>
<td>code 1</td>
<td>1007 Additional information 5</td>
<td>109 Additional information 6</td>
<td>Additional information 7</td>
<td>Additional information 8</td>
<td> </td>
</tr> 
Lo que busco es eliminar del array todas las posiciones en las que estas filas se repitan. De esta manera lo que busco es eliminar filas de esa tabla dublicadas. Pero!! no aquellas que se repiten enteras. Sino que la comparación solamente se haga desde la sexta columna de cada fila hasta el final de dicha fila. No se si me explico

Quiero comparar esto ($nodup_filter[0]):

Código HTML:
<td>code 1</td>
<td>1007 Additional information 5</td>
<td>109 Additional information 6</td>
<td>Additional information 7</td>
<td>Additional information 8</td>
<td> </td> 
con esto ($nodup_filter[1]):

Código HTML:
<td>Code 2</td>
<td>Additional information 1</td>
<td>Additional information 2</td>
<td>Additional information 3</td>
<td>Additional information 4</td>
<td> </td> 
y con esto ($nodup_filter[2]):
Código HTML:
<td>code 1</td>
<td>1007 Additional information 5</td>
<td>109 Additional information 6</td>
<td>Additional information 7</td>
<td>Additional information 8</td>
<td> </td> 
Si existe una coincidencia, entonces eliminamos una de las dos posiciones del array. Como podéis ver, $nodup_filter[0] y $nodup_filter[2] tienen la misma información desde su sexta columna hasta el final de la fila. Entonces una de las dos debe ser eliminada. Y así con cada fila (con cada posición del array).

Muchas gracias de antemano por vuestro tiempo y ayuda! Yo voy a seguirme rompiendo el coco para ver si consigo averiguar una manera. Salud!!
  #2 (permalink)  
Antiguo 27/02/2015, 07:12
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 15 años, 5 meses
Puntos: 1517
Respuesta: Como comparar varias columnas almacenadas en un array.

Trata a ver si array_unique te funciona.
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #3 (permalink)  
Antiguo 27/02/2015, 07:22
 
Fecha de Ingreso: agosto-2009
Mensajes: 91
Antigüedad: 15 años, 3 meses
Puntos: 2
Respuesta: Como comparar varias columnas almacenadas en un array.

Gracias por tu respuesta abimael! ya probé con array_unique antes de abrir el hilo. Pero tan sólo me permite comparar las filas enteras y lo que busco es comparar las filas únicamente a partir de la sexta columna.
  #4 (permalink)  
Antiguo 27/02/2015, 07:26
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 15 años, 5 meses
Puntos: 1517
Respuesta: Como comparar varias columnas almacenadas en un array.

¿Sexta columna? no entiendo ¿podrías abundar mas?
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #5 (permalink)  
Antiguo 27/02/2015, 07:36
 
Fecha de Ingreso: agosto-2009
Mensajes: 91
Antigüedad: 15 años, 3 meses
Puntos: 2
Respuesta: Como comparar varias columnas almacenadas en un array.

Sí, por supuesto. Este es el contenido de la primera posición del array $nodup_filter[0]:

<tr><td>29/06/2015</td><td>09:00</td><td>29/06/2015</td><td>12:00</td><td>3</td><td>code 1</td><td>1007 Additional information 5</td><td>109 Additional information </td><td>Additional information 7</td><td>Additional information 8</td><td> </td></tr>

Como ves, cada posición del array contiene una fila en html con sus columnas. Lo que busco es comparar la parte en negrita y si hay otra posición del array con esa misma cadena pues eliminar esa posición para evitar duplicados. Es difícil de explicar, espero haberme expresado bien. Gracias.
  #6 (permalink)  
Antiguo 27/02/2015, 07:52
Avatar de informacionsys  
Fecha de Ingreso: mayo-2011
Ubicación: Bogota D.C
Mensajes: 793
Antigüedad: 13 años, 6 meses
Puntos: 76
Respuesta: Como comparar varias columnas almacenadas en un array.

hola..

es dificil de entender lo que pretendes exactamente; con un ejemplo como deberia quedar el array final
  #7 (permalink)  
Antiguo 27/02/2015, 08:07
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 15 años, 5 meses
Puntos: 1517
Respuesta: Como comparar varias columnas almacenadas en un array.

Eso que quieres lograr es complejo. Te recomiendo mejor verificar si lo estás buscando en una base de datos hacer la consulta ahi y eliminar desde la consulta los duplicados.
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos
  #8 (permalink)  
Antiguo 27/02/2015, 10:00
 
Fecha de Ingreso: agosto-2009
Mensajes: 91
Antigüedad: 15 años, 3 meses
Puntos: 2
Respuesta: Como comparar varias columnas almacenadas en un array.

Cita:
Iniciado por informacionsys Ver Mensaje
hola..

es dificil de entender lo que pretendes exactamente; con un ejemplo como deberia quedar el array final
El array final en el ejemplo que he puesto debería quedar solamente con dos posiciones que son: $nodup_filter[0] y $nodup_filter[1]

O bien con: $nodup_filter[1] y $nodup_filter[2].

Puesto que si te fijas, $nodup_filter[0] y $nodup_filter[2] son iguales si los comparamos a partir de la columna 6 y por tanto uno de los dos debería considerarse duplicado y ser eliminado.

Fíjate que lo que quiero comparar en cada posición del array (en negrita) es:

$nodup_filter[0]:

<tr><td>29/06/2015</td><td>09:00</td><td>29/06/2015</td><td>12:00</td><td>3</td><td>code 1</td><td>1007 Additional information 5</td><td>109 Additional information </td><td>Additional information 7</td><td>Additional information 8</td><td> </td></tr>


$nodup_filter[2]:

<tr><td>29/06/2015</td><td>09:00</td><td>29/06/2015</td><td>12:00</td><td>3</td><td>code 1</td><td>1007 Additional information 5</td><td>109 Additional information </td><td>Additional information 7</td><td>Additional information 8</td><td> </td></tr>


Si te das cuenta una de esas dos posiciones del array debe ser eliminada (o bien eliminamos $nodup_filter[0] o bien eliminamos $nodup_filter[2]), puesto que todos los datos coinciden a partir de la columna 6.

En cambio en $nodup_filter[1] vemos que lo que está en negrita (a partir de la columna 6) no se encuentra duplicado con el resto de posiciones del array ($nodup_filter[0] o $nodup_filter[2]):

<tr><td>12/02/2015</td><td>16:00</td><td>14/04/2015</td><td>18:00</td><td>2</td><td>Code 2</td><td>Additional information 1</td><td>Additional information 2</td><td>Additional information 3</td><td>Additional information 4</td><td> </td></tr>



Cita:
Iniciado por abimaelrc Ver Mensaje
Eso que quieres lograr es complejo. Te recomiendo mejor verificar si lo estás buscando en una base de datos hacer la consulta ahi y eliminar desde la consulta los duplicados.
Estaba intentando no utilizar base de datos, puesto que es información extraída de un documento excel para ejecutar un script y no es necesario mantener la información almacenada.

Muchas gracias a ambos por la ayuda e interés.
  #9 (permalink)  
Antiguo 27/02/2015, 10:11
Avatar de informacionsys  
Fecha de Ingreso: mayo-2011
Ubicación: Bogota D.C
Mensajes: 793
Antigüedad: 13 años, 6 meses
Puntos: 76
Respuesta: Como comparar varias columnas almacenadas en un array.

en que momento se duplica el registro; asi viene de la DB ? ; ademas con el array_unique deberia funcionar porque viendo la primer publicacion $nodup_filter[0] y $nodup_filter[2] son iguales en todos las columnas; deberias hacer una var_dump o print_r del arreglo para ver la estructura..
  #10 (permalink)  
Antiguo 01/03/2015, 06:33
 
Fecha de Ingreso: agosto-2009
Mensajes: 91
Antigüedad: 15 años, 3 meses
Puntos: 2
Respuesta: Como comparar varias columnas almacenadas en un array.

Cita:
Iniciado por informacionsys Ver Mensaje
en que momento se duplica el registro; asi viene de la DB ? ; ademas con el array_unique deberia funcionar porque viendo la primer publicacion $nodup_filter[0] y $nodup_filter[2] son iguales en todos las columnas; deberias hacer una var_dump o print_r del arreglo para ver la estructura..
Gracias, tienes toda la razón. $nodup_filter[0] y $nodup_filter[2] en el ejemplo son iguales en todas las columnas, permíteme que lo corrija en el mensaje hilo para que quede más claro. En cuanto pueda hago el var_dump para que veas la estructura, ahora mismo no tengo el código a mano.

Gracias de nuevo!
  #11 (permalink)  
Antiguo 01/03/2015, 06:37
 
Fecha de Ingreso: agosto-2009
Mensajes: 91
Antigüedad: 15 años, 3 meses
Puntos: 2
Respuesta: Como comparar varias columnas almacenadas en un array.

La información del array no se recoge de una base de datos, lo obtengo leyendo un documento excel con PHPexcel.

No puedo editar el tema, pero quedaría así el contenido y no como está en el ejemplo:

$nodup_filter[0]

Código HTML:
<tr>
<td>10/03/2013</td>
<td>19:00</td>
<td>10/03/2013</td>
<td>11:00</td>
<td>5</td>
<td>code 1</td>                                                /* Estas son las columnas a comparar */
<td>1007 Additional information 5</td>                       /* Estas son las columnas a comparar */
<td>109 Additional information 6</td>                         /* Estas son las columnas a comparar */
<td>Additional information 7</td>                               /* Estas son las columnas a comparar */
<td>Additional information 8</td>                               /* Estas son las columnas a comparar */
<td> </td>                                                      /* Estas son las columnas a comparar */
</tr> 
$nodup_filter[2]

Código HTML:
<tr>
<td>29/06/2015</td>
<td>09:00</td>
<td>29/06/2015</td>
<td>12:00</td>
<td>3</td>
<td>code 1</td>                                                /* Estas son las columnas a comparar */
<td>1007 Additional information 5</td>                       /* Estas son las columnas a comparar */
<td>109 Additional information 6</td>                         /* Estas son las columnas a comparar */
<td>Additional information 7</td>                               /* Estas son las columnas a comparar */
<td>Additional information 8</td>                               /* Estas son las columnas a comparar */
<td> </td>                                                      /* Estas son las columnas a comparar */
</tr> 


El var_dump, en negrita lo que quiero comparar con cada posición del array, y si se encuentra repetida en alguna posición, entonces eliminar dicha posición entera. En este caso, se debería eliminar o bien la posición [0] o bien la posición [2] puesto que su parte en negrita coinciden.

array(11) {
[0]=> string(247) "<tr><td>10/03/2013</td><td>19:00</td><td>10/03/2013</td><td>11:00</td><td>5</td><td>code 1</td><td>1007 Additional information 5</td><td>109 Additional information 6 </td><td>Additional information 7</td><td>Additional information 8</td><td> </td></tr>"
[1]=> string(247) "<tr><td>29/06/2015</td><td>09:00</td><td>29/06/2015</td><td>12:00</td><td>3</td><td>Code 2</td><td>Additional information 1</td><td>Additional information 2</td><td>Additional information 3</td><td>Additional information 4</td><td> </td></tr> "
[2]=> string(252) "<tr><td>29/06/2015</td><td>09:00</td><td>29/06/2015</td><td>12:00</td><td>3</td><td>code 1</td><td>1007 Additional information 5</td><td>109 Additional information 6</td><td>Additional information 7</td><td>Additional information 8</td><td> </td></tr>"
[3]=> string(239) "<tr><td>09/06/2014</td><td>12:00</td><td>09/06/2014</td><td>13:00</td><td>6</td><td>code 3</td><td>1004 Additional information 10</td><td>102 Additional information 11</td><td>Additional information 12</td><td>Additional information 13</td><td> </td></tr>"
[4]=> string(244) "<tr><td>22/06/2015</td><td>09:00</td><td>22/06/2015</td><td>12:00</td><td>12</td><td>code 4</td><td>1008 Additional information 14</td><td>290 Additional information 15 </td><td>Additional information 16</td><td>Additional information 17</td><td> </td></tr> "
[5]=> string(235) "<tr><td>21/03/2012</td><td>23:00</td><td>21/03/2012</td><td>23:00</td><td>3</td><td>code 1</td><td>1011 Additional information 18</td><td>123 Additional information 19</td><td>Additional information 20</td><td>Additional information 21</td><td> </td></tr> "
[6]=> string(261) "<tr><td>01/02/2015</td><td>14:00</td><td>01/02/2015</td><td>14:00</td><td>6</td><td>code 7</td><td>1013 Additional information 22</td><td>178 Additional information 23</td><td>Additional information 24</td><td>Additional information 25</td><td> </td></tr> "
[7]=> string(253) "<tr><td>22/07/2015</td><td>15:00</td><td>22/07/2015</td><td>15:00</td><td>8</td><td>code 2</td><td>1407 Additional information 26</td><td>109 Additional information 27</td><td>Additional information 28</td><td>Additional information 29</td><td> </td></tr> "
[8]=> string(256) "<tr><td>17/06/2015</td><td>16:00</td><td>17/06/2015</td><td>16:00</td><td>3</td><td>code 3</td><td>1507 Additional information 30</td><td>109 Additional information 31</td><td>Additional information 32</td><td>Additional information 33</td><td> </td></tr> "
[9]=> string(290) "<tr><td>17/09/2015</td><td>18:00</td><td>17/09/2015</td><td>18:00</td><td>3</td><td>code 4</td><td>154 Additional information 34</td><td>110 Additional information 35</td><td>Additional information 36</td><td>Additional information 37</td><td> </td></tr> "
[10]=> string(234) "<tr><td>24/06/2015</td><td>20:00</td><td>24/06/2015</td><td>20:00</td><td>8</td><td>code 6</td><td>1777 Additional information 38</td><td>109 Additional information 39</td><td>Additional information 40</td><td>Additional information 41</td><td> </td></tr> "
}



Gracias!!!

Última edición por jurassicboy; 01/03/2015 a las 15:45

Etiquetas: almacenadas, columnas, tabla
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 14:46.