Analyzing your prompt, please hold on...
An error occurred while retrieving the results. Please refresh the page and try again.
SVG es un formato de gráficos vectoriales diseñado principalmente para la web, a menudo utilizado en documentos HTML. La principal ventaja de SVG es su excepcional capacidad para escalarse a cualquier tamaño sin perder calidad. Además, SVG ofrece varias ventajas, como programabilidad, tamaño de archivo reducido, opciones de estilo, interactividad, etc., todo lo cual puede mejorar el atractivo visual y la funcionalidad de una página web.
Descargar SVG no es tan fácil como parece. Si alguna vez ha utilizado el botón derecho del ratón para guardar o abrir una imagen de una página web, probablemente se habrá dado cuenta de que los archivos SVG son difíciles de extraer de un sitio web. A veces, hacer clic con el botón derecho del ratón no permite abrirlo en una pestaña nueva ni guardarlo. ¿Qué puede hacer? Puede inspeccionar manualmente el código HTML para identificar las etiquetas SVG y determinar dónde empieza y termina el contenido SVG. Afortunadamente, existe una solución más sencilla: puede utilizar Aspose.HTML for Java para descargar archivos SVG de un sitio web mediante programación.
Los gráficos SVG de las páginas web pueden incrustarse de dos formas: como Inline SVG dentro del HTML o como external SVG referenciado mediante URL. En este artículo, exploraremos cómo extraer SVG tanto en línea como externos utilizando la API de Aspose.HTML for Java. Con este método, puede recopilar automáticamente todos los SVG de un sitio web sin tener que buscarlos manualmente en el código. Sumerjámonos de lleno en la extracción de SVG sin esfuerzo.
Las imágenes Inline SVG son elementos SVG <svg> cuyo contenido describe la imagen. Inline SVG se refiere a la incrustación de código SVG directamente en el código HTML en lugar de vincular a un archivo SVG externo. Se trata de una técnica muy utilizada para crear iconos, logotipos y otros elementos gráficos para sitios web.
Para guardar imágenes SVG en línea, buscaremos todos los elementos <svg> en un documento HTML y utilizaremos la propiedad OuterHTML de la clase
Element para obtener su contenido. Por lo tanto, para descargar SVG desde el sitio web, usted debe tomar algunos pasos siguientes:
HTMLDocument, pasando la URL de la página web que contiene imágenes SVG en línea.<svg> presentes en el documento HTML.images.getOuterHTML() para obtener el contenido del elemento SVG y, a continuación, utilice el método FileHelper.writeAllText() para escribir el contenido SVG en un archivo local .svg. 1// How to extract inline SVG images from a webpage using Java
2
3// Open a document you want to download inline SVG images from
4final HTMLDocument document = new HTMLDocument("https://products.aspose.com/html/net/");
5
6// Collect all inline SVG images
7HTMLCollection images = document.getElementsByTagName("svg");
8
9for (int i = 0; i < images.getLength(); i++) {
10 // Save every image to a local file system
11 FileHelper.writeAllText("{i}.svg", images.get_Item(i).getOuterHTML());
12}Nota: Respete siempre las leyes de copyright cuando trabaje con archivos SVG. Algunos archivos SVG, como logotipos de empresas o gráficos de marca, pueden estar protegidos, y utilizarlos sin permiso puede considerarse plagio. Antes de extraer o utilizar cualquier archivo SVG en sus proyectos, compruebe las condiciones de uso del sitio web o póngase en contacto con el propietario del sitio para obtener el permiso correspondiente.
SVG externo es un archivo SVG almacenado fuera de un documento HTML y cargado en el documento utilizando, por ejemplo, una etiqueta <img>. Separar los archivos SVG del HTML permite reutilizar la misma imagen SVG en varios lugares sin duplicar el código, lo que hace que las páginas web sean más eficientes y fáciles de mantener.
Las imágenes SVG externas se representan mediante el elemento <img>, que a su vez también puede hacer referencia a otros tipos de imágenes, por lo que las imágenes SVG deben filtrarse más. Veamos cómo descargar SVG de un sitio web utilizando la biblioteca Aspose.HTML for Java:
Url) y pase la URL del sitio web del que desea extraer las imágenes SVG externas.<img> del documento HTML utilizando el método
getElementsByTagName("img").src de cada elemento de imagen utilizando el método
getAttribute(“src”) y almacena los valores en un Set..svg comprobando si cada URL termina en .svg, y añadirlas a una nueva lista.HTMLDocument.document.getContext().getNetwork().send(request) y compruebe si la respuesta es correcta.FileHelper.writeAllBytes() para guardar el contenido SVG en el sistema de archivos local. 1// Download external SVG images from HTML using Java
2
3// Open a document you want to download external SVGs from
4final HTMLDocument document = new HTMLDocument("https://products.aspose.com/html/net/");
5
6// Collect all image elements
7HTMLCollection images = document.getElementsByTagName("img");
8
9// Create a distinct collection of relative image URLs
10java.util.Set<String> urls = new HashSet<>();
11for (Element element : images) {
12 urls.add(element.getAttribute("src"));
13}
14
15// Filter out non SVG images
16java.util.List<String> svgUrls = new ArrayList<>();
17for (String url : urls) {
18 if (url.endsWith(".svg")) {
19 svgUrls.add(url);
20 }
21}
22// Create absolute SVG image URLs
23java.util.List<Url> absUrls = svgUrls.stream()
24 .map(src -> new Url(src, document.getBaseURI()))
25 .collect(Collectors.toList());
26
27// foreach to while statements conversion
28for (Url url : absUrls) {
29 // Create a downloading request
30 final RequestMessage request = new RequestMessage(url);
31
32 // Download SVG image
33 final ResponseMessage response = document.getContext().getNetwork().send(request);
34
35 // Check whether response is successful
36 if (response.isSuccess()) {
37 String[] split = url.getPathname().split("/");
38 String path = split[split.length - 1];
39
40 // Save file to a local file system
41 FileHelper.writeAllBytes($o(path), response.getContent().readAsByteArray());
42 }
43}Este enfoque automatiza la extracción de imágenes SVG externas de una página web, ahorrándole el tiempo y el esfuerzo de descargar manualmente cada archivo. Esto es ideal para diseñadores y desarrolladores que quieren extraer SVGs de sitios sin necesidad de sumergirse en el código fuente.
Aspose.HTML ofrece un conjunto de Aplicaciones web HTML gratuitas en línea, que incluyen conversores, fusiones, herramientas SEO, generadores de código HTML, utilidades URL y mucho más. Estas herramientas basadas en navegador funcionan en todos los sistemas operativos y no requieren la instalación de ningún software adicional. Si necesita convertir o fusionar archivos, extraer datos web, generar código HTML o analizar páginas para SEO, puede hacerlo todo directamente en la web. Agilice sus tareas diarias y aumente su productividad con nuestras sencillas aplicaciones web HTML, en cualquier momento y lugar.
Analyzing your prompt, please hold on...
An error occurred while retrieving the results. Please refresh the page and try again.