AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / Perguntas / 78432943
Accepted
HangarRash
HangarRash
Asked: 2024-05-06 00:26:08 +0800 CST2024-05-06 00:26:08 +0800 CST 2024-05-06 00:26:08 +0800 CST

Qual XSLT é necessário para extrair e transformar este XHTML específico?

  • 772

Estou tentando extrair um subconjunto de algum HTML de um arquivo maior e, em seguida, realizar algumas transformações no resultado. Fiz alguns progressos, mas faltam uma ou duas peças para fazer este trabalho conforme desejado.

Aqui está uma versão bastante simplificada do XHTML que desejo transformar:

<html>
<head>
<!-- lots of stuff I don't care about -->
</head>
<body>
<div>
  <!-- lots of stuff I don't care about -->
  <div>
     <!-- lots of stuff I don't care about -->
     <div id="key_div">
         <div id="ignore_this">
           <!-- lots of stuff I don't care about -->
         </div>
         <p>More junk I don't want</p>
         <p>Even more junk I don't want</p>
         <h2><span class="someClass" id="someID">Header</span></h2>
         <p>Stuff I want to keep</p>
         <!-- A lot of stuff I want to keep -->
         <p>More stuff I want to keep</p>
         <ul>
           <li><a href="/some/old/path">Fun Place</a></li>
           <li><a href="/some/old/other">Better Place</a></li>
         </ul>
     </div>
     <!-- lots of stuff I don't care about -->
  </div>
  <!-- lots of stuff I don't care about -->
</div>
</body>
</html>

Quero extrair tudo da <h2>tag até o restante do conteúdo dentro do <div>com o idof "key_div". Mas também quero transformar o <h2>em um mais simples <h1>e preciso modificar os hrefs da lista. O resultado final deverá ficar assim:

<html>
<head>
<!-- My own header stuff -->
</head>
<body>
 <h1>Header</h1>
 <p>Stuff I want to keep</p>
 <!-- A lot of stuff I want to keep -->
 <p>More stuff I want to keep</p>
 <ul>
   <li><a href="/new/path">Fun Place</a></li>
   <li><a href="/new/other">Better Place</a></li>
 </ul>
</body>
</html>

Consegui fazer a maior parte da extração básica sem nenhuma das transformações desejadas usando o seguinte XSL:

<xsl:stylesheet version="1.0"
 xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
 xmlns:x="http://www.w3.org/1999/xhtml"
 exclude-result-prefixes="x">
 <xsl:output indent="yes" encoding="utf-8"/>

 <xsl:template match="/">
  <html>
   <head>
     <title>My Title</title>
   </head>
   <body>
    <xsl:apply-templates/>
   </body>
  </html>
 </xsl:template>

 <xsl:template match="div[@id='key_div']/*">
  <xsl:copy-of select="."/>
 </xsl:template>

 <xsl:template match="div[@id='ignore_this']"/>

 <xsl:template match="text()"/>
</xsl:stylesheet>

Isto resulta em:

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>My Title</title>
</head>
<body>
<p>More junk I don't want</p>
<p>Even more junk I don't want</p>
<h2><span class="someClass" id="someID">Header</span></h2>
<p>Stuff I want to keep</p>
<p>More stuff I want to keep</p>
<ul>
           <li><a href="/some/old/path">Fun Place</a></li>
           <li><a href="/some/old/other">Better Place</a></li>
         </ul>
</body>
</html>

Não sei como remover as coisas antes do arquivo <h2>.

Não sei como me transformar <h2><span class="someClass" id="someID">Header</span></h2>ou <h1>Header</h1>como transformar o hrefs. Todas as minhas tentativas de combinar uma transformação com a extração geralmente acabam sem conteúdo.

Haverá algumas outras transformações que preciso realizar, mas por enquanto vou me concentrar neste exemplo para começar. Menciono isso para que quaisquer respostas possíveis não impeçam quaisquer outras transformações possíveis.

html
  • 2 2 respostas
  • 35 Views

2 respostas

  • Voted
  1. Best Answer
    y.arazim
    2024-05-06T00:57:58+08:002024-05-06T00:57:58+08:00

    Tente algo como:

    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    
    <xsl:template match="/html">
        <html>
            <head>
                <!-- your own header stuff -->
            </head>
            <body>
                <xsl:apply-templates select="//div[@id='key_div']/h2"/>
            </body>
        </html>
    </xsl:template>
    
    <xsl:template match="h2">
        <h1>
            <xsl:value-of select="." />
        </h1>
        <xsl:apply-templates select="following-sibling::*"/>
    </xsl:template>
    
    <xsl:template match="@href">
        <xsl:attribute name="href">
            <xsl:text>/new/</xsl:text>
            <xsl:value-of select="substring-after(., '/old/')" />
        </xsl:attribute>
    </xsl:template>
    
    <xsl:template match="@*|node()">
        <xsl:copy>
            <xsl:apply-templates select="@*|node()"/>
        </xsl:copy>
    </xsl:template>
    
    </xsl:stylesheet>
    
    • 1
  2. Martin Honnen
    2024-05-06T00:40:57+08:002024-05-06T00:40:57+08:00

    Supondo que os elementos de entrada HTML não estejam em nenhum namespace (como em seus exemplos, embora você fale sobre XHTML), é suficiente usar a transformação de identidade (declarada em XSLT 3 a <xsl:mode on-no-match="shallow-copy"/>) mais modelos para o corpo, o h2, o h2/span e o href atributo:

      <xsl:template match="body">
        <xsl:copy>
          <xsl:apply-templates select=".//div[@id = 'key_div']/h2/(., following-sibling::node())"/>
        </xsl:copy>
      </xsl:template>
      
      <xsl:template match="h2">
        <h1>
          <xsl:apply-templates/>
        </h1>
      </xsl:template>
      
      <xsl:template match="h2/span">
        <xsl:apply-templates/>
      </xsl:template>
    
      <xsl:template match="ul/li/a/@href">
        <xsl:attribute name="{node-name()}" select="replace(., '/some/old', '/new')"/>
      </xsl:template>
    

    Usando XSLT 2/3, XPath 2/3 em alguns lugares, XSLT 1/XPath 1 é

      <xsl:template match="body">
        <xsl:copy>
          <xsl:variable name="h2" select=".//div[@id = 'key_div']/h2"/>
          <xsl:apply-templates select="$h2 | $h2/following-sibling::node()"/>
        </xsl:copy>
      </xsl:template>
      
      <xsl:template match="h2">
        <h1>
          <xsl:apply-templates/>
        </h1>
      </xsl:template>
      
      <xsl:template match="h2/span">
        <xsl:apply-templates/>
      </xsl:template>
    
      <xsl:template match="ul/li/a/@href">
        <xsl:attribute name="{name()}">
          <xsl:value-of select="concat('/new', substring-after(., '/some/old'))"/>
        </xsl:attribute>
      </xsl:template>
    

    Com a transformação de identidade adicionada, seria

    <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
      version="1.0">
    
      <xsl:output method="html" indent="no" version="5"/>
    
      <xsl:template match="@* | node()">
        <xsl:copy>
          <xsl:apply-templates select="@* | node()"/>
        </xsl:copy>
      </xsl:template>
    
      <xsl:template match="body">
        <xsl:copy>
          <xsl:variable name="h2" select=".//div[@id = 'key_div']/h2"/>
          <xsl:apply-templates select="$h2 | $h2/following-sibling::node()"/>
        </xsl:copy>
      </xsl:template>
      
      <xsl:template match="h2">
        <h1>
          <xsl:apply-templates/>
        </h1>
      </xsl:template>
      
      <xsl:template match="h2/span">
        <xsl:apply-templates/>
      </xsl:template>
    
      <xsl:template match="ul/li/a/@href">
        <xsl:attribute name="{name()}">
          <xsl:value-of select="concat('/new', substring-after(., '/some/old'))"/>
        </xsl:attribute>
      </xsl:template>
    
    </xsl:stylesheet>
    
    • 0

relate perguntas

  • Usando o ponto de código para renderizar o ícone delineado em vez de preenchido no Material Design Google Fonts

  • Como fazer tab como uma forma de seta usando css

  • Desenhando linhas inclinadas dentro da tabela em html e css

  • Tabela HTML com 2 linhas de células seguidas

  • Como criar material angular mat-grid-list

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Por que esse código Java simples e pequeno roda 30x mais rápido em todas as JVMs Graal, mas não em nenhuma JVM Oracle?

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Quando devo usar um std::inplace_vector em vez de um std::vector?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Marko Smith

    Estou tentando fazer o jogo pacman usando apenas o módulo Turtle Random e Math

    • 1 respostas
  • Martin Hope
    Aleksandr Dubinsky Por que a correspondência de padrões com o switch no InetAddress falha com 'não cobre todos os valores de entrada possíveis'? 2024-12-23 06:56:21 +0800 CST
  • Martin Hope
    Phillip Borge Por que esse código Java simples e pequeno roda 30x mais rápido em todas as JVMs Graal, mas não em nenhuma JVM Oracle? 2024-12-12 20:46:46 +0800 CST
  • Martin Hope
    Oodini Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores? 2024-12-12 06:27:11 +0800 CST
  • Martin Hope
    sleeptightAnsiC `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso? 2024-11-09 07:18:53 +0800 CST
  • Martin Hope
    The Mad Gamer Quando devo usar um std::inplace_vector em vez de um std::vector? 2024-10-29 23:01:00 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST
  • Martin Hope
    MarkB Por que o GCC gera código que executa condicionalmente uma implementação SIMD? 2024-02-17 06:17:14 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve