Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > OOP
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

 
 
Herramientas Buscar en Tema Desplegado
  #5  
Antiguo 02-06-2017
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Cita:
Empezado por oscarac Ver Mensaje
lo hice de esta manera
se puede identificar la tabla con los elementos que contiene via delphi?
esta parte es la que me interesa, se que puedo buscar un texto y de ahi ir tanteando, pero pense que habria alguna otra forma?
Aquí te va una solución. Pero toma en cuenta lo que comenta AgustinOrtu porque tan pronto cambien el formato de salida, tendrías que alterar tu código.

Estoy suponiendo que tu formulario contiene un component IdHTTP y un ListView. Defines entonces el método

Código Delphi [-]
TForm1 = class(TForm)
public
  procedure Consulta(Anio, Mes: String);
end;

Este método consultará el año y mes indicados (como cadenas) y llenará el ListView con los datos obtenidos:

Código Delphi [-]
uses ActiveX, MSHTML, DateUtils;

const
  URL = 'http://www.sunat.gob.pe/cl-at-ittipcam/tcS01Alias';

procedure TForm1.Consulta(Anio, Mes: String);
var
  Params: TStrings;
  Response: String;
  Documento: OleVariant;
  Tablas: OLeVariant;
  Tabla: OleVariant;
  Fila: OleVariant;
  Celda: OleVariant;
  Item: TListItem;
  I, J: Integer;

begin
  lvwDatos.Clear;

  // Obtenemos la página (esto es necesario porque si no se hace, el POST que sigue falla)
  IdHTTP.Get(URL);

  // Efectuamos el POST con los parámetros requeridos
  Params := TStringList.Create();
  Params.Values['anho'] := Anio;
  Params.Values['mes'] := Mes;

  try
    Response := IdHTTP.Post(URL, Params);
  finally
    Params.Free;
  end;

  // Creamos un documento HTML con los datos obtenidos
  Documento := coHTMLDocument.Create as IHTMLDocument;
  Documento.Write(Response);
  Documento.Close();

  // Obtenemos la tabla con los datos
  Tablas := Documento.getElementsByTagName('table');
  Tabla := Tablas.item(1);

  // Recorremos la tabla y llenamos el ListView
  for I := 1 to Tabla.rows.length - 1 do
  begin
    Fila := Tabla.rows.item(I);

    for J := 0 to (Fila.cells.length div 3) - 1 do
    begin
      Item := lvwDatos.Items.Add;

      Celda := Fila.cells.item(3*J);
      Item.Caption := Trim(Celda.innerText);

      Celda := Fila.cells.item(3*J + 1);
      Item.SubItems.Add(Trim(Celda.innerText));

      Celda := Fila.cells.item(3*J + 2);
      Item.SubItems.Add(Trim(Celda.innerText));
    end;
  end;
end;

LineComment Saludos
Responder Con Cita
 



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Obtener los datos máximos paciencia_mucha SQL 24 30-11-2008 13:38:05
Obtener datos consulta SQL adrall SQL 1 04-03-2008 19:16:42
Obtener datos JavierO Tablas planas 1 02-08-2005 19:30:18
Obtener datos de un DVD Video JoseQ Varios 1 08-02-2005 20:08:57
obtener filas que contienen unos datos y no contienen otros datos Angel Firebird e Interbase 14 10-06-2003 10:11:23


La franja horaria es GMT +2. Ahora son las 01:47:24.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi