mirror of
https://github.com/hwchase17/langchain.git
synced 2025-10-23 19:44:05 +00:00
- **Description:** the layout of html pages can be variant based on the bootstrap framework or the styles of the pages. So we need to have a splitter to transform the html tags to a proper layout and then split the html content based on the provided list of tags to determine its html sections. We are using BS4 library along with xslt structure to split the html content using an section aware approach. - **Dependencies:** No new dependencies - **Twitter handle:** @m_setayesh Please make sure your PR is passing linting and testing before submitting. Run `make format`, `make lint` and `make test` from the root of the package you've modified to check this locally. See contribution guidelines for more information on how to write/run tests, lint, etc: https://python.langchain.com/docs/contributing/ If you're adding a new integration, please include: 1. a test for the integration, preferably unit tests that do not rely on network access, 2. an example notebook showing its use. It lives in `docs/docs/integrations` directory. If no one reviews your PR within a few days, please @-mention one of @baskaryan, @eyurtsev, @hwchase17. --> --------- Co-authored-by: Bagatur <baskaryan@gmail.com>
29 lines
1.0 KiB
HTML
29 lines
1.0 KiB
HTML
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
|
|
<!-- Copy all nodes and attributes by default -->
|
|
<xsl:template match="@*|node()">
|
|
<xsl:copy>
|
|
<xsl:apply-templates select="@*|node()"/>
|
|
</xsl:copy>
|
|
</xsl:template>
|
|
|
|
<!-- Match any element that has a font-size attribute larger than 20px -->
|
|
<xsl:template match="*[@style[contains(., 'font-size')]]">
|
|
<!-- Extract the font size value from the style attribute -->
|
|
<xsl:variable name="font-size" select="substring-before(substring-after(@style, 'font-size:'), 'px')" />
|
|
<!-- Check if the font size is larger than 20 -->
|
|
<xsl:choose>
|
|
<xsl:when test="$font-size > 20">
|
|
<!-- Replace the element with a header tag -->
|
|
<h1>
|
|
<xsl:apply-templates select="@*|node()"/>
|
|
</h1>
|
|
</xsl:when>
|
|
<xsl:otherwise>
|
|
<!-- Keep the original element -->
|
|
<xsl:copy>
|
|
<xsl:apply-templates select="@*|node()"/>
|
|
</xsl:copy>
|
|
</xsl:otherwise>
|
|
</xsl:choose>
|
|
</xsl:template>
|
|
</xsl:stylesheet> |