![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
|||
|
|||
|
Gracias por la respuesta
Lo he probado y sigue pasando lo mismo.... y el caso es que si trato el archivo como si no conociera su formato y me desplazo hasta el offset siguiente al final del array of char con seek y leo los 4 bytes del integer siguiente, lo lee sin problemas y lo añade al memo... Cada vez estoy mas confuso... |
|
#2
|
|||
|
|||
|
Ya sé cual es el problema, solucionarlo NO
He descubierto que si declaro el tipo como array of char no acabo en el offset que empieza el integer; por eso así no lo mostraba bien, y con seek(archivo,offset) si. El integer empieza en el offset 58.
Empiezo en el offset 24, y debería acabar en el 57. Si lo declaro como array[1..33] of char acabo en el offset 56, y si lo declaro array[1..34] of char, acabo en el 60. ¿Que tamaño o tipo tendría que darle para que ocupe exactamente los 34 bytes qye tiene asignados para ese texto Unicode? |
|
#3
|
||||
|
||||
|
¿?
En un principio [1..34]of char ó [1..17]of widechar tendrían que colocarte en el 57. Es realmente extraño. Se me ocurre que, para salir del paso, podrías leer el fichero como secuencia de SmallInts o Word (Int16), ya que: - para los datos Int16 ya lo tienes. - para hallar los Int32, tendrías que pasar dos Int16 a hexadecimal, juntarlos, y calcular el Int32. - cada carácter Unicode equivale a un Int16. Es una idea, pero tu código debería funcionar. ¿Sería mucho pedir un archivo de ejemplo para que pudiéramos hacer pruebas? Con un ejemplo de lo que se debería obtener de él, claro. Saludos. |
|
#4
|
|||
|
|||
|
¿Mucho pedir???
Al contrario, muy muy agradecido por tu ayuda. Lo he subido aqui: http://rapidshare.com/files/69149915/FEI_004.pgmf.html Su estructura es esta: Field-----------------Size (bytes)--------------Type-----------------------------------Contenido en el archivo FileFingerprint------------2---------------------Int16-------------------------------------- 1000 FileVersion---------------2---------------------Int16-------------------------------------- 100 BlockCount--------------4--------------------- Int32-------------------------------------- 2 BlockFingerprint----------2---------------------Int16--------------------------------------1010 BlockVersion-------------2---------------------Int16-------------------------------------- 100 RecordCount------------4----------------------Int32-------------------------------------- 1 RecordSize--------------4----------------------Int32--------------------------------------70 CheckSum--------------4----------------------UInt32--------------------------------------3120033703 CourseName-----------34----------------------char[34]Unicode <--Este es el problematico ---'FEI 004' WattSlopePulse---------4----------------------Int32<-------------------------------------- 1 Con un editor hexa he comprobado que el string unicode empieza en el offset 24, exactanente donde debería teniendo en cuenta el tamaño de los tipos anteriores, y acaba en el 57; en el 58 empieza el integer que vá detrás, y con el filemon, compruebo donde acaba el array of char según su tamaño. El texto que contiene coincide, en este caso con el del archivo, FEI 004, en unicode. Gracias Última edición por JosepZ fecha: 12-11-2007 a las 10:54:29. |
|
#5
|
||||
|
||||
|
Hola.
Bueno, es bastante curioso lo que te pasa. Yo implementé este código:
La segunda parte era para ver el balor de los bytes. Efectivamente, después de la cadena de texto (que declaras demasiado larga, tienes que quitarle un carácter, 0..17 son 36 bytes) hay un byte que vale "1", pero que leyéndolo con la estructura no aparece. Me parece que habrá que buscar otra solución (o un buen porqué). ¡Ah! y si encuentras/has encontrado la solución, postéala, no me dejes con las ganas de saber qué pasaba ![]() Saludos. |
|
#6
|
|||
|
|||
|
El byte de valor "1" no aparece por que array[0..16] of widechar lee 36 bytes, en vez de 34, y el integer "WattsSopePulse" se desplaza.
Lo he comprobado con el file monitor;empieza a leer en el offset 0 y lee 60 bytes, dos por encima del offset 58, donde empieza el integer. Ni idea de por que, pero lo hace. Por eso con seek, le das el offset y el tamaño y lo lee sin problemas. |
|
#7
|
||||
|
||||
|
Me dejas de piedra.
Esto es como aquella división que me puse de pequeño y no fui capaz de resolver (con un número no llegaba, y con el siguiente me pasaba ).¿Controlas algún otro entorno a parte de Delphi? Creo que sería buena idea probar, incluso hacerse una librería (DLL) para leer el dichoso archivo. Aún me faltan unas pocas lecciones de C, pero si llego pronto igual puedo probar. De verdad no se me ocurre nada más. Saludos extraños. |
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
Temas Similares
|
||||
| Tema | Autor | Foro | Respuestas | Último mensaje |
| Cargar archivo y guardarlo en tabla | Carliviris | Varios | 4 | 30-09-2006 00:39:43 |
| cargar archivo este si | gulder | API de Windows | 12 | 04-05-2005 06:26:21 |
| cargar un archivo sys en builder | israelgs | C++ Builder | 0 | 08-10-2004 21:25:32 |
| Cargar Archivo | srangel | JAVA | 0 | 03-09-2004 21:19:15 |
| Cargar archivo chm | esocrates | Varios | 1 | 27-07-2003 09:58:02 |
|