scala小工具:读取EXCEL自动生成初始化语句

简介: 数仓项目中经常遇到业务手工发数据,然后要求补录数据的情况。每次通过excel拉取费时费力,使用小工具提高效率

maven依赖:

<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>4.1.0</version>

脚本:

package Excel

import java.io.{File, FileInputStream, InputStream, PrintWriter}

import org.apache.poi.hssf.usermodel.HSSFWorkbook
import org.apache.poi.ss.usermodel.{Cell, CellType}

object TestExcel {
def main(args: Array[String]): Unit = {

//读取excel
val file = new File(args(0))
val stream = new FileInputStream(file)
//输出文件
var output=new PrintWriter("script.sql")
//工作簿
val workBook = new HSSFWorkbook(stream)
//获取sheets集合
val sheets = workBook.sheetIterator()
//sheet递归
while (sheets.hasNext) {
  //获取当前sheet
  val sheet = sheets.next()
  //获取rows集合
  val rows = sheet.rowIterator
  //行递归
  while (rows.hasNext) {
    //获取当前row
    val row = rows.next()
    //获取cell集合
    val cells = row.cellIterator()
    //sql语句
    var sql = "insert into " + sheet.getSheetName + " values("
    //内容
    var content: String = ""
    //cell遍历
    while (cells.hasNext) {
      var cell = cells.next()
      content += (cell.getCellType match {
        case CellType.NUMERIC => "," + cell.getNumericCellValue + ""
        case _ => ",'" + cell.getStringCellValue.toString.replace("'","\\'") + "'"
      }
        )
    }
    //生成sql
    sql+=content.replaceFirst(",","")+");"
    //写入文件
    output.write(sql)
    output.write("\n")
  }
}
output.close()

}
}

目录
相关文章
|
2月前
|
easyexcel Java 测试技术
读取Excel还用POI?试试这款开源工具EasyExcel
读取Excel还用POI?试试这款开源工具EasyExcel
70 0
|
6月前
|
Unix 数据安全/隐私保护 Python
python自动生成Excel表格数据并发送邮件案例
python自动生成Excel表格数据并发送邮件案例
|
6月前
|
Python
python自动生成含样式的Excel表格数据案例
python自动生成含样式的Excel表格数据案例
VS2005(excel2007)利用Automation(OLD Automation)方法。将Excel当成组件服务器的编译错误 我的系统盘和office都装在d盘。 自动生成的import有问题
VS2005(excel2007)利用Automation(OLD Automation)方法。将Excel当成组件服务器的编译错误 我的系统盘和office都装在d盘。 自动生成的import有问题
|
4月前
|
数据挖掘 数据安全/隐私保护 Python
【Python数据分析】<数据分析工具>基于Excel的数据分析
【1月更文挑战第22天】【Python数据分析】<数据分析工具>基于Excel的数据分析
|
3月前
|
自然语言处理 安全 Unix
一键式Excel分词统计工具:如何轻松打包Python脚本为EXE
一键式Excel分词统计工具:如何轻松打包Python脚本为EXE
49 0
|
4月前
|
JSON 数据格式
将json格式的数据快速转换为excel,使用在线工具轻松搞定
将json格式的数据快速转换为excel,使用在线工具轻松搞定
176 0
|
4月前
|
Scala
Scala中的模式匹配:强大的匹配和转换工具
Scala中的模式匹配:强大的匹配和转换工具
21 1
Excel工具-HUTOOL-读取Excel
Excel工具-HUTOOL-读取Excel
|
9月前
|
存储 Java BI
探索Apache POI库:强大的Excel和Word文档处理工具
在企业应用和数据处理中,Excel和Word文档是常见的数据交换和存储格式。然而,处理和操作这些文档可能是一项繁琐的任务。Apache POI库作为一款强大的文档处理工具,可以帮助我们更轻松地进行Excel和Word文档的读写、编辑和生成。本文将深入探讨Apache POI库的基本概念、特点,以及如何在实际应用中使用它进行文档处理。
437 0