Estoy extracción de los datos de la tabla en la página https://br.investing.com/indices/major-indices
Soy capaz de extraer los datos perfectamente, pero no sé cómo escribir a un JSON, en el siguiente formato.
código de selenio para la extracción de datos:
public void AcessarPagina() {
System.out.println("*** Abrindo a Pagina de Extração *** \n");
driver.get("https://br.investing.com/indices/major-indices");
WebDriverWait AguardarTabela = new WebDriverWait(driver, 20);
AguardarTabela.until(ExpectedConditions.presenceOfElementLocated(By
.id("cross_rates_container")));
System.out.println("*** Iniciando a Extração *** \n");
WebElement TabelaCabecalho = driver.findElement(By.id("cross_rates_container"));
List<WebElement> Cabecalho = TabelaCabecalho.findElements(By.tagName("th"));
for (int i = 0; i < Cabecalho.size(); i++) {
System.out.print(Cabecalho.get(i).getText() + ";");
}
WebElement TabelaDados = driver.findElement(By.id("cross_rates_container"));
List<WebElement> Linhas = TabelaDados.findElements(By.tagName("tr"));
List<WebElement> ListaColunas = null;
for (WebElement row : Linhas) {
System.out.println();
ListaColunas = row.findElements(By.tagName("td"));
for (WebElement column : ListaColunas) {
System.out.print(column.getText() + ";");
}
}
}
JSON formato que necesito:
[ {
"indice" : "Dow 30",
"ultimo" : "23.185,62",
"maxima" : "23.189,76",
"minima" : "21.285,37",
"variacao" : "+1.985,00",
"variacao2" : "+9,36%",
"hora" : "13/03"
}, {
"indice" : "S&P 500 VIX",
"ultimo" : "23.185,62",
"maxima" : "23.189,76",
"minima" : "21.285,37",
"variacao" : "+1.985,00",
"variacao2" : "+9,36%",
"hora" : "13/03"
} ]
Mapeo del objeto a un objeto Java, a continuación, utilizando como Chris Jackson menciona es probablemente la mejor opción. He reunido un ejemplo de lo que puede hacer:
Aquí está el objeto Java que podría sostener sus valores:
public class TableElement {
private String indice;
private String ultimo;
private String maxima;
private String minima;
private String variacao;
private String variacao2;
private String hora;
public String getIndice() {
return indice;
}
public void setIndice(String indice) {
this.indice = indice;
}
// Add all getters and setters ...
}
Nota - Los captadores y definidores son necesarios porque eso es lo que utiliza para recuperar Jackson / valores establecidos en un objeto desde y hacia json
Y en realidad la cartografía que json
sería algo como esto:
StockTable stockTable = new StockTable();
List<TableElement> stocks = new ArrayList<>();
TableElement tableElement = new TableElement();
tableElement.setIndice("Dow 30");
tableElement.setUltimo("23.185,62");
tableElement.setMaxima("23.189,76");
tableElement.setMinima("21.285,37");
tableElement.setVariacao("+1.985,00");
tableElement.setVariacao2("+9,36%");
tableElement.setHora("13/03");
TableElement tableElement2 = new TableElement();
tableElement2.setIndice("S&P 500 VIX");
tableElement2.setUltimo("23.185,62");
tableElement2.setMaxima("23.189,76");
tableElement2.setMinima("21.285,37");
tableElement2.setVariacao("+1.985,00");
tableElement2.setVariacao2("+9,36%");
tableElement2.setHora("13/03");
stocks.add(tableElement);
stocks.add(tableElement2);
ObjectMapper objectMapper = new ObjectMapper();
try {
System.out.println(objectMapper.writerWithDefaultPrettyPrinter()
.writeValueAsString(stocks));
} catch (JsonProcessingException e) {
e.printStackTrace();
}
Y sería producir una salida que se parece a esto:
[ {
"indice" : "Dow 30",
"ultimo" : "23.185,62",
"maxima" : "23.189,76",
"minima" : "21.285,37",
"variacao" : "+1.985,00",
"variacao2" : "+9,36%",
"hora" : "13/03"
}, {
"indice" : "S&P 500 VIX",
"ultimo" : "23.185,62",
"maxima" : "23.189,76",
"minima" : "21.285,37",
"variacao" : "+1.985,00",
"variacao2" : "+9,36%",
"hora" : "13/03"
} ]