Maison interface Web tutoriel HTML Comment transférer du HTML vers Excel

Comment transférer du HTML vers Excel

Feb 21, 2024 pm 10:48 PM
文件格式转换 transfert HTML transfert Excel

Comment transférer du HTML vers Excel

Comment transférer du HTML vers Excel nécessite des exemples de code spécifiques

Introduction :
Dans le travail réel, nous devons parfois exporter des données de pages Web au format Excel. HTML est un langage de balisage Web courant, tandis qu'Excel est un tableur couramment utilisé. Les formats des deux sont différents, une conversion est donc nécessaire. Cet article expliquera comment utiliser JavaScript et des bibliothèques tierces pour réaliser la fonction de transfert de HTML vers des fichiers Excel et donnera des exemples de code spécifiques.

1. Utilisez JavaScript pour transférer du HTML vers Excel

  1. Créez un tableau HTML
    Tout d'abord, nous devons créer un tableau en HTML et mettre les données à exporter dans le tableau. Par exemple, voici un tableau avec trois lignes et trois colonnes :
<table id="myTable">
  <tr>
    <th>姓名</th>
    <th>年龄</th>
    <th>性别</th>
  </tr>
  <tr>
    <td>张三</td>
    <td>25</td>
    <td>男</td>
  </tr>
  <tr>
    <td>李四</td>
    <td>30</td>
    <td>女</td>
  </tr>
</table>
Copier après la connexion
  1. Ajouter un bouton d'exportation et un écouteur d'événement
    Ajoutez un bouton en HTML qui déclenche l'événement d'exportation lorsque vous cliquez sur le bouton. Les boutons peuvent être ajoutés comme suit :
<button onclick="exportToExcel()">导出Excel</button>
Copier après la connexion
Copier après la connexion

Ensuite, nous devons ajouter un écouteur d'événement pour que le bouton déclenche la fonction d'exportation. Utilisez JavaScript pour écrire le code suivant :

function exportToExcel() {
  // 导出表格逻辑
}
Copier après la connexion
  1. Implémentez la logique d'exportation et générez des fichiers Excel
    Pour implémenter la logique d'exportation, nous pouvons utiliser JavaScript pour convertir le contenu du tableau HTML en un fichier Excel. Dans la fonction exportée, nous devons effectuer les étapes suivantes :

(1) Créer un nouveau classeur Excel :

var wb = new ExcelJS.Workbook();
var ws = wb.addWorksheet('Sheet 1');
Copier après la connexion

(2) Parcourez toutes les lignes et colonnes du tableau HTML et remplissez les données dans la feuille de calcul Excel Medium :

var rows = document.getElementById("myTable").rows;
for (var i = 0; i < rows.length; i++) {
  var cells = rows[i].cells;
  for (var j = 0; j < cells.length; j++) {
    ws.getCell(i + 1, j + 1).value = cells[j].innerText;
    // 根据需要设置单元格样式
    ws.getCell(i + 1, j + 1).alignment = { horizontal: 'left' };
  }
}
Copier après la connexion

(3) Enregistrez le fichier Excel :

wb.xlsx.writeBuffer().then(function(buffer) {
  saveAs(new Blob([buffer], { type: 'application/octet-stream' }), 'data.xlsx');
});
Copier après la connexion

Ajoutez ces codes à la fonction "exportToExcel", le code complet est le suivant :

function exportToExcel() {
  var wb = new ExcelJS.Workbook();
  var ws = wb.addWorksheet('Sheet 1');

  var rows = document.getElementById("myTable").rows;
  for (var i = 0; i < rows.length; i++) {
    var cells = rows[i].cells;
    for (var j = 0; j < cells.length; j++) {
      ws.getCell(i + 1, j + 1).value = cells[j].innerText;
      ws.getCell(i + 1, j + 1).alignment = { horizontal: 'left' };
    }
  }

  wb.xlsx.writeBuffer().then(function(buffer) {
    saveAs(new Blob([buffer], { type: 'application/octet-stream' }), 'data.xlsx');
  });
}
Copier après la connexion

2. Utilisez une bibliothèque tierce pour transférer du HTML vers Excel
Dans en plus de JavaScript natif En plus du fonctionnement, nous pouvons également utiliser des bibliothèques tierces pour réaliser la fonction de transfert de HTML vers Excel, comme la bibliothèque « AlaSQL ». Voici le code spécifique pour utiliser la bibliothèque AlaSQL :

  1. Présentez la bibliothèque AlaSQL et la bibliothèque ExcelJS
    Tout d'abord, nous devons présenter la bibliothèque AlaSQL et les scripts de la bibliothèque ExcelJS en HTML, qui peuvent être introduits des manières suivantes :
<script src="https://cdn.jsdelivr.net/npm/alasql"></script>
<script src="https://cdn.jsdelivr.net/npm/exceljs"></script>
Copier après la connexion
  1. Modifier la fonction d'export
    Dans la fonction d'export, nous utilisons la méthode "alasql" de la bibliothèque AlaSQL pour convertir le tableau HTML en fichier Excel. Modifiez le code de la fonction exportée comme suit :
function exportToExcel() {
  var tableData = [];
  var rows = document.getElementById("myTable").rows;
  for (var i = 0; i < rows.length; i++) {
    var rowData = [];
    var cells = rows[i].cells;
    for (var j = 0; j < cells.length; j++) {
      rowData.push(cells[j].innerText);
    }
    tableData.push(rowData);
  }

  var opts = {
    sheetid: 'Sheet 1',
    headers: true,
    skipHeader: true
  };

  var res = alasql('SELECT * INTO XLSX("data.xlsx",?) FROM ?', [opts, [tableData]]);
}
Copier après la connexion
  1. Ajouter des boutons et des écouteurs d'événements
    De même, ajoutez des boutons et ajoutez des écouteurs d'événements en HTML :
<button onclick="exportToExcel()">导出Excel</button>
Copier après la connexion
Copier après la connexion

L'exemple de code complet du fichier HTML est le suivant :



  
    
    HTML转存为Excel
    
    
  
  
    
姓名 年龄 性别
张三 25
李四 30
<button onclick="exportToExcel()">导出Excel</button> <script> function exportToExcel() { var tableData = []; var rows = document.getElementById("myTable").rows; for (var i = 0; i < rows.length; i++) { var rowData = []; var cells = rows[i].cells; for (var j = 0; j < cells.length; j++) { rowData.push(cells[j].innerText); } tableData.push(rowData); } var opts = { sheetid: 'Sheet 1', headers: true, skipHeader: true }; var res = alasql('SELECT * INTO XLSX("data.xlsx",?) FROM ?', [opts, [tableData]]); } </script>
Copier après la connexion

Résumé :
Cet article explique comment utiliser JavaScript et des bibliothèques tierces pour transférer du HTML vers des fichiers Excel et donne des exemples de code spécifiques. Grâce à ces codes, nous pouvons facilement transférer les données de la page Web au format Excel pour répondre aux besoins d'exportation dans le travail réel. J'espère que cet article sera utile à tout le monde.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quelles sont les meilleures pratiques pour la compatibilité entre les navigateurs dans HTML5? Quelles sont les meilleures pratiques pour la compatibilité entre les navigateurs dans HTML5? Mar 17, 2025 pm 12:20 PM

L'article examine les meilleures pratiques pour assurer la compatibilité des navigateurs de HTML5, en se concentrant sur la détection des fonctionnalités, l'amélioration progressive et les méthodes de test.

Quel est le but du & lt; Progress & gt; élément? Quel est le but du & lt; Progress & gt; élément? Mar 21, 2025 pm 12:34 PM

L'article traite du HTML & lt; Progress & GT; élément, son but, son style et ses différences par rapport au & lt; mètre & gt; élément. L'objectif principal est de l'utiliser & lt; Progress & gt; pour l'achèvement des tâches et & lt; mètre & gt; pour stati

Quel est le but du & lt; datalist & gt; élément? Quel est le but du & lt; datalist & gt; élément? Mar 21, 2025 pm 12:33 PM

L'article traite du HTML & lt; Datalist & GT; élément, qui améliore les formulaires en fournissant des suggestions de saisie semi-automatique, en améliorant l'expérience utilisateur et en réduisant les erreurs. COMMANDE COMPRES: 159

Comment utiliser les attributs de validation du formulaire HTML5 pour valider l'entrée utilisateur? Comment utiliser les attributs de validation du formulaire HTML5 pour valider l'entrée utilisateur? Mar 17, 2025 pm 12:27 PM

L'article discute de l'utilisation des attributs de validation de formulaire HTML5 comme les limites requises, motifs, min, max et longueurs pour valider la saisie de l'utilisateur directement dans le navigateur.

Quel est le but du & lt; mètre & gt; élément? Quel est le but du & lt; mètre & gt; élément? Mar 21, 2025 pm 12:35 PM

L'article traite du HTML & lt; mètre & gt; élément, utilisé pour afficher des valeurs scalaires ou fractionnaires dans une plage, et ses applications courantes dans le développement Web. Il différencie & lt; mètre & gt; De & lt; Progress & gt; et ex

Quelle est la balise Meta de la fenêtre? Pourquoi est-ce important pour une conception réactive? Quelle est la balise Meta de la fenêtre? Pourquoi est-ce important pour une conception réactive? Mar 20, 2025 pm 05:56 PM

L'article traite de la balise Meta de la fenêtre, essentielle pour la conception Web réactive sur les appareils mobiles. Il explique comment une utilisation appropriée garantit une mise à l'échelle optimale du contenu et une interaction utilisateur, tandis que la mauvaise utilisation peut entraîner des problèmes de conception et d'accessibilité.

Quel est le but du & lt; iframe & gt; étiqueter? Quelles sont les considérations de sécurité lorsque vous l'utilisez? Quel est le but du & lt; iframe & gt; étiqueter? Quelles sont les considérations de sécurité lorsque vous l'utilisez? Mar 20, 2025 pm 06:05 PM

L'article traite du & lt; iframe & gt; L'objectif de Tag dans l'intégration du contenu externe dans les pages Web, ses utilisations courantes, ses risques de sécurité et ses alternatives telles que les balises d'objet et les API.

HTML est-il facile à apprendre pour les débutants? HTML est-il facile à apprendre pour les débutants? Apr 07, 2025 am 12:11 AM

HTML convient aux débutants car il est simple et facile à apprendre et peut rapidement voir les résultats. 1) La courbe d'apprentissage de HTML est fluide et facile à démarrer. 2) Il suffit de maîtriser les balises de base pour commencer à créer des pages Web. 3) Flexibilité élevée et peut être utilisée en combinaison avec CSS et JavaScript. 4) Les ressources d'apprentissage riches et les outils modernes soutiennent le processus d'apprentissage.

See all articles