Estoy recorriendo filas dentro de una tabla que tiene dos tds. Obtengo los datos correctos dentro de la matriz, pero quiero colocar cada bucle dentro de una matriz de objetos con pares de valores clave.
Esto es lo que tengo hasta ahora:
let test = await page.evaluate(() => { let dataStructure = [] for (let i = 1; i < 13; i++) { let main = document.querySelector(".test > table > tbody > tr:nth-child(" + i + ")") let data = main.querySelectorAll("td + td") data.forEach((x) => { dataStructure.push( x.innerHTML ) }) } return dataStructure })
La salida se ve así:
[ '', '', '', 'Chicago', 'IL', '', 'US', '(12.34567, -12.34567)', ]
Pero estoy tratando de hacer algo como esto:
[ { adresss: '', apt: '', message: '', city: 'Chicago', state: 'IL', zip: '', country: 'US', coordinates: '(12.34567, -12.34567)', } ]
La manera simple de hacer esto (asumiendo que las propiedades están siempre en el mismo orden, etc.) sería simplemente asignar los valores a las propiedades, por ejemplo...
// Let's say that 'data' is the array of values from the table. // Adjust accordingly for the intended layout... let dataObject = { address: data[0], apt: data[1], // Etc... coordinates: data[7] }
Hay varias otras formas en que esto podría hacerse (por ejemplo, podría iterar a través de una matriz de nombres de propiedad y usarlos como asignaciones)
// Again, assume 'data' is the input array... // Define a list of property names... let properties = ["address", "apt", "message", "city", "state", "zip", "country", "coordinates"]; // Create an empty object for storing the values... let dataObject = {}; for(let v in data) { // Assign the value of the v'th data item to the v'th property name of the object dataObject[properties[v]] = data[v] }
Suponiendo que tiene algún atributo en su elemento td que puede ayudar a proporcionar las claves en la datastructure
de datos, como:
<td data-keyname="country">US</td>
let test = await page.evaluate(() => { let dataStructure = [] let obj = {} for (let i = 1; i < 13; i++) { let main = document.querySelector(".test > table > tbody > tr:nth-child(" + i + ")") let data = main.querySelectorAll("td + td") data.forEach((x) => { obj[x.getAttribute('data-keyname')] = x.innerHTML }) } dataStructure.puch(obj) return dataStructure })