En un script de Python, quería probar diferentes cadenas HTML usando la misma lógica. Mi enfoque fue recorrer un rango para crear múltiples instancias de las variables de cadena HTML, pero no funcionó como se esperaba.
# DO NOT DO THIS for i in range(1, 5): html = f"html{i}" soup = BeautifulSoup(html, "html.parser") print('----', soup)
El comportamiento que estaba observando se debe a la forma en que se interpreta la cadena formateada f"html{i}". En mi código, f"html{i}" se evalúa como los literales "html1", "html2", "html3" y "html4" en lugar del contenido de las variables denominadas html1, html2, etc.
Python no reemplaza automáticamente f"html{i}" con el valor de la variable cuyo nombre se crea dinámicamente, como html1 o html2. En cambio, evalúa la cadena como un patrón fijo compuesto por el prefijo "html" seguido del valor de i.
Si quiero usar el contenido de las variables predefinidas html1, html2, etc., necesito recuperar explícitamente sus valores, por ejemplo usando un diccionario para asignar nombres de cadenas a su contenido real.
Aquí hay un ejemplo que ilustra esto:
from bs4 import BeautifulSoup # Define the variables html1 = "Test 1" html2 = "Test 2" html3 = "Test 3" html4 = "Test 4" # Store them in a dictionary for easy access html_dict = { "html1": html1, "html2": html2, "html3": html3, "html4": html4 } # Iterate and process each html content for i in range(1, 5): key = f"html{i}" html = html_dict[key] soup = BeautifulSoup(html, "html.parser") print('----', soup)
Definir variables:
Diccionario para búsqueda de variables:
Iterar sobre claves:
Analizar e imprimir:
---- Test 1 ---- Test 2 ---- Test 3 ---- Test 4
Este enfoque accede dinámicamente al contenido de las variables según el índice de iteración e imprime correctamente el contenido deseado.
Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.
Copyright© 2022 湘ICP备2022001581号-3