XLSXVue教程:如何使用Vue.js讀取和操作Excel文件

在日常的開發工作中,我們會經常遇到需要讀取和操作Excel文件的情況。如果使用純JavaScript或jQuery來實現這一功能,會比較繁瑣和複雜。而使用Vue.js可以簡化這個過程,並且提供更好的用戶體驗。下面將為大家詳細介紹如何使用Vue.js讀取和操作Excel文件。

一、引入xlsx組件庫

在使用Vue.js讀取和操作Excel文件之前,我們需要先安裝並引入xlsx組件庫。

npm install --save xlsx

在組件中引入xlsx組件庫:

import XLSX from 'xlsx'

二、讀取Excel文件

在Vue.js中,使用<input type=”file”/>標籤可以讓用戶選擇本地文件上傳。然後使用FileReader API將文件讀入內存。接下來,我們需要使用XLSX組件庫的方法來解析Excel文件。

下面是讀取Excel文件的代碼示例:

<template>
  <div>
    <input type="file" @change="onFileChange" />
    <table>
      <tr v-for="(item, index) in data" :key="index">
        <td v-for="(value, key) in item" :key="key">{{ value }}</td>
      </tr>
    </table>
  </div>
</template>

<script>
import XLSX from 'xlsx'

export default {
  data () {
    return {
      data: []
    }
  },
  methods: {
    onFileChange (event) {
      let fileList = event.target.files
      const reader = new FileReader()
      reader.onload = (e) => {
        const data = e.target.result
        let workbook = XLSX.read(data, { type: 'binary' })
        let sheet_name_list = workbook.SheetNames
        let worksheet = workbook.Sheets[sheet_name_list[0]]
        let jsonData = XLSX.utils.sheet_to_json(worksheet, { header: 1 })
        this.data = jsonData.map((item) => ({
          date: item[0],
          category: item[1]
        }))
      }
      reader.readAsBinaryString(fileList[0])
    }
  }
}
</script>

三、操作Excel文件

讀取完畢之後,我們可以對Excel文件進行一些操作。比如,篩選、排序、添加等等。下面是一個示例,可以根據時間篩選出數據。

<template>
  <div>
    <input type="file" @change="onFileChange" />
    <select v-model="selectDate">
      <option v-for="date in dateList" :key="date" :value="date">{{ date }}</option>
    </select>
    <table>
      <tr v-for="(item, index) in filterData" :key="index">
        <td v-for="(value, key) in item" :key="key">{{ value }}</td>
      </tr>
    </table>
  </div>
</template>

<script>
import XLSX from 'xlsx'

export default {
  data () {
    return {
      data: [],
      selectDate: '',
      filterData: []
    }
  },
  methods: {
    onFileChange (event) {
      let fileList = event.target.files
      const reader = new FileReader()
      reader.onload = (e) => {
        const data = e.target.result
        let workbook = XLSX.read(data, { type: 'binary' })
        let sheet_name_list = workbook.SheetNames
        let worksheet = workbook.Sheets[sheet_name_list[0]]
        let jsonData = XLSX.utils.sheet_to_json(worksheet, { header: 1 })
        this.data = jsonData.map((item) => ({
          date: item[0],
          category: item[1]
        }))
        this.dateList = Array.from(new Set(this.data.map((item) => item.date)))
        this.selectDate = this.dateList[0]
      }
      reader.readAsBinaryString(fileList[0])
    }
  },
  computed: {
    filterData () {
      return this.data.filter((item) => item.date === this.selectDate)
    }
  }
}
</script>

四、導出Excel文件

除了能夠讀取Excel文件,Vue.js還可以用於導出Excel文件。我們可以使用SheetJS組件庫的方法將數據導出為Excel文件。下面是一個導出Excel文件的代碼示例:

<template>
  <div>
    <button @click="exportExcel">導出</button>
  </div>
</template>

<script>
import XLSX from 'xlsx'

export default {
  data () {
    return {
      exportData: [
        [ '姓名', '年齡', '性別', '職業', '愛好' ],
        [ '小紅', '25', '女', '程序猿', '游泳, 打乒乓球' ],
        [ '小明', '22', '男', '產品經理', '閱讀, 看電影' ],
        [ '小王', '23', '男', 'UI 設計師', '畫畫, 玩遊戲' ]
      ]
    }
  },
  methods: {
    exportExcel () {
      const wb = XLSX.utils.book_new()
      const ws = XLSX.utils.aoa_to_sheet(this.exportData)
      XLSX.utils.book_append_sheet(wb, ws, 'Sheet1')
      XLSX.writeFile(wb, '導出的文件.xlsx')
    }
  }
}
</script>

五、小結

以上就是使用Vue.js讀取和操作Excel文件的全部內容了。不難發現,使用Vue.js能夠輕鬆地實現複雜的Excel文件操作,而且非常適合需要處理大量數據的場景。希望本文能夠對大家有所幫助。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/219771.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-09 11:01
下一篇 2024-12-09 11:01

相關推薦

  • MQTT使用教程

    MQTT是一種輕量級的消息傳輸協議,適用於物聯網領域中的設備與雲端、設備與設備之間的數據傳輸。本文將介紹使用MQTT實現設備與雲端數據傳輸的方法和注意事項。 一、準備工作 在使用M…

    編程 2025-04-29
  • Python3.6.5下載安裝教程

    Python是一種面向對象、解釋型計算機程序語言。它是一門動態語言,因為它不會對程序員提前聲明變量類型,而是在變量第一次賦值時自動識別該變量的類型。 Python3.6.5是Pyt…

    編程 2025-04-29
  • Python棧操作用法介紹

    如果你是一位Python開發工程師,那麼你必須掌握Python中的棧操作。在Python中,棧是一個容器,提供後進先出(LIFO)的原則。這篇文章將通過多個方面詳細地闡述Pytho…

    編程 2025-04-29
  • vue下載無後綴名的文件被加上後綴.txt,有後綴名的文件下載正常問題的解決

    本文旨在解決vue下載無後綴名的文件被加上後綴.txt,有後綴名的文件下載正常的問題,提供完整的代碼示例供參考。 一、分析問題 首先,需了解vue中下載文件的情況。一般情況下,我們…

    編程 2025-04-29
  • Deepin系統分區設置教程

    本教程將會詳細介紹Deepin系統如何進行分區設置,分享多種方式讓您了解如何規劃您的硬盤。 一、分區的基本知識 在進行Deepin系統分區設置之前,我們需要了解一些基本分區概念。 …

    編程 2025-04-29
  • 如何在Java中拼接OBJ格式的文件並生成完整的圖像

    OBJ格式是一種用於表示3D對象的標準格式,通常由一組頂點、面和紋理映射坐標組成。在本文中,我們將討論如何將多個OBJ文件拼接在一起,生成一個完整的3D模型。 一、讀取OBJ文件 …

    編程 2025-04-29
  • Python程序文件的拓展

    Python是一門功能豐富、易於學習、可讀性高的編程語言。Python程序文件通常以.py為文件拓展名,被廣泛應用於各種領域,包括Web開發、機器學習、科學計算等。為了更好地發揮P…

    編程 2025-04-29
  • Python中讀入csv文件數據的方法用法介紹

    csv是一種常見的數據格式,通常用於存儲小型數據集。Python作為一種廣泛流行的編程語言,內置了許多操作csv文件的庫。本文將從多個方面詳細介紹Python讀入csv文件的方法。…

    編程 2025-04-29
  • 為什麼用cmd運行Java時需要在文件內打開cmd為中心

    在Java開發中,我們經常會使用cmd在命令行窗口運行程序。然而,有時候我們會發現,在運行Java程序時,需要在文件內打開cmd為中心,這讓很多開發者感到疑惑,那麼,為什麼會出現這…

    編程 2025-04-29
  • 如何使用Python獲取某一行

    您可能經常會遇到需要處理文本文件數據的情況,在這種情況下,我們需要從文本文件中獲取特定一行的數據並對其進行處理。Python提供了許多方法來讀取和處理文本文件中的數據,而在本文中,…

    編程 2025-04-29

發表回復

登錄後才能評論