Foro de elhacker.net

Programación => Programación Visual Basic => Mensaje iniciado por: Cromatico en 4 Marzo 2011, 23:34 pm



Título: Consulta interpretacion texto
Publicado por: Cromatico en 4 Marzo 2011, 23:34 pm
Hola que tal nuevamenteee :P:P
Queria consultar una cosita... Tengo un texto que es todo seguido, pero quiero dividirlo...
Como para poner un ejemplo, supongamos que son todos USUARIOS, usuario1, usuario2, usuario3...

El texto me lo devuelve una web php con "echo"...
Seria asi:
Código:
dato1|dato2|dato3|dato4|1 dato1|dato2|dato3|dato4|2 dato1|dato2|dato3|dato4|3

Como ven, son 4 datos y despues del 4to separador esta el identificador de cada usuario.

La cuestion es que no se me ocurre como identificar los 4 datos + el identificador de cada "usuario"...

Estaba pensando en contar los separadores y al llegar a 4, que haga un split y corte como si fuera un usuario... Pero tampoco se como hacerlo...
Va, se me ocurre readfield pero no se no me convence, hay alguna otra alternativa?

Gracias!!!


Título: Re: Consulta interpretacion texto
Publicado por: Edu en 4 Marzo 2011, 23:47 pm
No se entiende bien lo q dices pero parece q usando split simplemente se puede pero veo q lo has intentado no se, explica mejor.


Título: Re: Consulta interpretacion texto
Publicado por: Cromatico en 5 Marzo 2011, 00:36 am
mmm se me complica para explicarlo quizas xD

aver yo tengo este texto:
Código:
dato1|dato2|dato3|dato4|1 dato1|dato2|dato3|dato4|2 dato1|dato2|dato3|dato4|3

Se supone que son 3 usuarios que tienen 4 datos cada uno y al final el identificador...
dato1|dato2|dato3|dato4|1
dato1|dato2|dato3|dato4|2
dato1|dato2|dato3|dato4|3

Quiero separarlos osea:
Código:
dim Usuario() as string
Usuario(1) = dato1|dato2|dato3|dato4|1
Usuario(2) = dato1|dato2|dato3|dato4|2
Usuario(3) = dato1|dato2|dato3|dato4|3

No intente hacer split, lo usaria para luego de tener los datos de cada usuario, ahi si hacer un split y separar cada uno de los datos del usuario...

Pero teniendolo asi (original):
Código:
dato1|dato2|dato3|dato4|1 dato1|dato2|dato3|dato4|2 dato1|dato2|dato3|dato4|3

Como puedo separar cada usuario?


Título: Re: Consulta interpretacion texto
Publicado por: Edu en 5 Marzo 2011, 01:20 am
Fa tienes razon, yo no se mucho pero tendria q saber como hacer un array de arrays q es lo q falta creo mira esto:

Código
  1. Dim Data As String
  2. Dim Usuario1() As String, Usuario2() As String
  3. Dim Usuario3() As String
  4.  
  5.  
  6. Data = "dato1|dato2|dato3|dato4|1 dato1|dato2|dato3|dato4|2 dato1|dato2|dato3|dato4|3"
  7.  
  8. Usuario1() = Split(Data, "|" & 1)
  9.  
  10. Usuario2() = Split(Usuario1(1), "|" & 2)
  11.  
  12. Usuario3() = Split(Usuario2(1), "|" & 3)
  13.  
  14. MsgBox Usuario1(0)
  15. MsgBox Usuario2(0)
  16. MsgBox Usuario3(0)
  17.  

Lo hice de esa forma por si sabes hacer lo de un array dentro de otro xD yo tendria q saberlo talvez son los vasos de mas q tengo xD me fui!!



Título: Re: Consulta interpretacion texto
Publicado por: raul338 en 5 Marzo 2011, 01:37 am
Hay otras formas, pero a mi me encanta las expresiones regulares :xD

Código
  1. Public Function GetData(ByVal strText As String) As Collection
  2. Dim cTemp                       As New Collection
  3. Dim oRegExp                     As Object
  4. Dim oMatch                      As Object
  5. Dim oMatches                    As Object
  6.  
  7.    Set oRegExp = CreateObject("VBScript.RegExp")
  8.  
  9.    With oRegExp
  10.        .Pattern = "[\w\d]+\|[\w\d]+\|[\w\d]+\|[\w\d]+\|(\d+)"
  11.        .Global = True
  12.        .IgnoreCase = True
  13.    End With
  14.  
  15.    Set oMatches = oRegExp.Execute(strText)
  16.  
  17.    For Each oMatch In oMatches
  18.        cTemp.Add oMatch.SubMatches(0)
  19.    Next
  20.  
  21.    Set GetData = cTemp
  22. End Function
  23.  
  24. Private Sub Form_Load()
  25. Dim vItem                       As Variant
  26. Const S                         As String = "dato1|dato2|dato3|dato4|1 dato1|dato2|dato3|dato4|2 dato1|dato2|dato3|dato4|3"
  27.    For Each vItem In GetData(S)
  28.        MsgBox vItem
  29.    Next
  30. End Sub
  31.  


Título: Re: Consulta interpretacion texto
Publicado por: Cromatico en 5 Marzo 2011, 02:37 am
Mmmm raul tu funcion me devuelve el identificador de cada usuario verdad? Y como obtengo los datos de cada uno siendo asi?

Gracias a los 2!


Título: Re: Consulta interpretacion texto
Publicado por: Cromatico en 5 Marzo 2011, 02:57 am
Perdon por el doble post, ya lo solucione, no sera la mejor manera, pero me funciona perfecto, aca les dejo como hice!
Código:
Private Sub Form_Load()
Dim i As Integer, l As Integer
Dim Data As String, X As String, Datos As String, Dats() As String
Dim Usuario(100) As String

Datos = "0 dato1|dato2|dato3|dato4|1 dato5|dato6|dato7|dato8|2 dato9|dato10|dato11|dato12|3 dato13|dato14|dato15|dato16|4 dato17|dato18|dato19|dato20|5"
X = Right(Data, 1) 'ultimo usuario (en este caso seria x = 5)

For i = 1 To X 'hacemos el recorrido del usuario 1 hasta x (ultimo usuario)
Datos = ReadField((i * 4) - 3, Data, Asc("|")) & ReadField((i * 4) - 2, Data, Asc("|")) & ReadField((i * 4) - 1, Data, Asc("|")) & ReadField(i * 4, Data, Asc("|"))
Dats() = Split(Datos, i - 1 & " ")
Usuario(i) = Dats(1)
Next i

For l = 1 To X
MsgBox Usuario(l)
Next l
End Sub


Private Function ReadField(ByVal Pos As Integer, ByVal Text As String, ByVal SepASCII As Integer) As String
    Dim i As Integer
    Dim LastPos As Integer
    Dim CurChar As String * 1
    Dim FieldNum As Integer
    Dim Seperator As String
    Seperator = Chr$(SepASCII)
    LastPos = 0
    FieldNum = 0
    For i = 1 To Len(Text)
        CurChar = Mid$(Text, i, 1)
        If CurChar = Seperator Then
            FieldNum = FieldNum + 1
            If FieldNum = Pos Then
                ReadField = Mid$(Text, LastPos + 1, (InStr(LastPos + 1, Text, Seperator, vbTextCompare) - 1) - (LastPos))
                Exit Function
            End If
            LastPos = i
        End If
    Next i
    FieldNum = FieldNum + 1
    If FieldNum = Pos Then
        ReadField = Mid$(Text, LastPos + 1)
    End If
End Function



Título: Re: Consulta interpretacion texto
Publicado por: BlackZeroX en 5 Marzo 2011, 05:02 am
.
Si usas el Split con ese tipo de datos deberias usar una estructura para que todo sea mas organizado.

Temibles Lunas!ˇ.