Foros del Web » Programando para Internet » ASP Clásico »

Recorrer CSV y borrar a partir de cierto punto

Estas en el tema de Recorrer CSV y borrar a partir de cierto punto en el foro de ASP Clásico en Foros del Web. Hola, quisiera hacer lo siguiente: tengo un archivo CSV en el que tengo un registro en cada fila. Lo que quiero es ir leyendo ese ...
  #1 (permalink)  
Antiguo 09/11/2010, 02:07
Avatar de angel_dope  
Fecha de Ingreso: noviembre-2002
Ubicación: Valencia
Mensajes: 737
Antigüedad: 22 años
Puntos: 8
Recorrer CSV y borrar a partir de cierto punto

Hola, quisiera hacer lo siguiente: tengo un archivo CSV en el que tengo un registro en cada fila. Lo que quiero es ir leyendo ese archivo y comprobar el valor de la tercera columna. Cuando se cumpla una condición (que la fecha de ese campo se encuentre en los últimos 30 días) quiero borrar todos los registros que vienen después.
¿Hay alguna forma de hacerlo?? Otra opción sería leer todos los registros anteriores y copiarlos a un archivo nuevo, el resultado sería el mismo.
Muchas gracias por adelantado, Salu2
__________________
Vayamos por Partes :: Jack el Destripador
  #2 (permalink)  
Antiguo 09/11/2010, 03:50
Avatar de angel_dope  
Fecha de Ingreso: noviembre-2002
Ubicación: Valencia
Mensajes: 737
Antigüedad: 22 años
Puntos: 8
Respuesta: Recorrer CSV y borrar a partir de cierto punto

Bueno, ya lo tengo resuelto, al final lo que hago es ir recorriendo el archivo y mientras que no se cumple la condición voy escribiendo las lineas en un archivo nuevo. Cuando ya se cumple dejo de escribir. A continuación solo falta borrar el archivo antiguo y renombrar el nuevo. Os dejo el código por si le sirve a alguien, falta la parte final de borrar y renombrar archivos.

Código ASP:
Ver original
  1. <%@LANGUAGE="VBSCRIPT" CODEPAGE="1252"%>
  2. <%
  3. Const Filename = "./exportacion/prueba.csv"    ' file to read
  4. Const ForReading = 1, ForWriting = 2, ForAppending = 3
  5. Const TristateUseDefault = -2, TristateTrue = -1, TristateFalse = 0
  6.  
  7. nombre_archivo = "pruebas_nuevo.csv"
  8. PathXLS        = Server.MapPath("./exportacion/"&nombre_archivo)
  9.  
  10. set fsob = CreateObject("Scripting.FileSystemObject")
  11. set fs = fsob.CreateTextFile(PathXLS, true)
  12. ' Create a filesystem object
  13. Dim FSO
  14. set FSO = server.createObject("Scripting.FileSystemObject")
  15.  
  16. ' Map the logical path to the physical system path
  17. Dim Filepath
  18. Filepath = Server.MapPath(Filename)
  19.  
  20. if FSO.FileExists(Filepath) Then
  21.  
  22.     ' Get a handle to the file
  23.     Dim file    
  24.     set file = FSO.GetFile(Filepath)
  25.  
  26.     ' Get some info about the file
  27.  
  28.     ' Open the file
  29.     Dim TextStream
  30.     Set TextStream = file.OpenAsTextStream(ForReading, TristateUseDefault)
  31.  
  32.     ' Read the file line by line
  33.     dim contador
  34.     contador=1
  35.     fecha_limite=date-30   
  36.  
  37.     Do While Not TextStream.AtEndOfStream
  38.         Dim Line
  39.         Line = TextStream.readline
  40.         if contador>1 then     
  41.                 ' Do something with "Line"
  42.             campos = split(line,";")
  43.             fecha_limite=cdate(fecha_limite)
  44.             fecha_actual=cdate(campos(1))
  45.             if fecha_actual>fecha_limite then
  46.                 no_sale=1
  47.             end if
  48.     '       Line = Line & vbCRLF   
  49.             if no_sale<>1 then
  50.                 fs.writeline(Line)
  51.             end if
  52.         end if
  53.         contador=contador+1
  54.     Loop
  55.     Set TextStream = nothing
  56.    
  57. Else
  58.  
  59.     Response.Write "<h3><i><font color=red> File " & Filename &_
  60.                        " does not exist</font></i></h3>"
  61.  
  62. End If
  63.  
  64. Set FSO = nothing
  65. %>
__________________
Vayamos por Partes :: Jack el Destripador

Etiquetas: borrar, csv, partir, punto, recorrer
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 20:12.