網站首頁 編程語言 正文
需求:
把exel表格中的內容,導入到sqlite3數據中,就行數據的求
- 交集
- 差集
- 并集
最后在保存到excel表格中;
數據庫表結
?
package main
import (
"database/sql"
"fmt"
"github.com/360EntSecGroup-Skylar/excelize"
_ "github.com/mattn/go-sqlite3"
"log"
"time"
)
//定義數據庫的全局變量信息
const (
dbDriverName = "sqlite3"
dbname = "./datacheck.db"
)
//讀取與寫入的數據放在一塊----寫入數據庫文件
func exceTosqliteChckdata(db *sql.DB, ExcelName string) {
//f, err := excelize.OpenFile("./sx1.xlsx")
f, err := excelize.OpenFile(ExcelName)
if err != nil {
fmt.Println("打開excel文件錯誤", err)
return
}
rows := f.GetRows("ck")
for index, row := range rows {
//indiex-->是行號 1,2,3,。。。
if index == 0 { //第一行‘表頭’數據不寫入數據庫
continue
}
//fmt.Println("inex=", index)
//fmt.Println(row) //[4000027 三層南走廊東 4000027 hkGxwgL6u03f]
Gbid := row[0] //gb id 4000027
devicename := row[1] //設備名稱 --三層南走廊東
fmt.Println(Gbid, devicename) //錄入數據內容
sql := `insert into checkdata (gbid, devicename) values(?,?)`
stmt, _ := db.Prepare(sql)
_, err := stmt.Exec(Gbid, devicename)
if err != nil {
log.Fatalln("插入數據失敗")
}
}
}
func exceTosqliteNetwl(db *sql.DB, ExcelName string) {
//f, err := excelize.OpenFile("./sx1.xlsx")
f, err := excelize.OpenFile(ExcelName)
if err != nil {
fmt.Println("打開excel文件錯誤!", err)
return
}
rows := f.GetRows("data")
for index, row := range rows {
if index == 0 { //第一行‘表頭’數據不寫入數據庫--跳過第一行數據,不讀
continue
}
//fmt.Println(row)
Gbid := row[5] //gb id -表格的第五列是gbid
devicename := row[0] //設備名稱 --三層南走廊東
fmt.Println(Gbid, devicename) //錄入數據內容
sql := `insert into netwl (gbid, devicename) values(?,?)`
stmt, _ := db.Prepare(sql)
_, err := stmt.Exec(Gbid, devicename)
if err != nil {
log.Fatalln("插入數據失敗")
}
}
}
func main() {
//初始化數據sqlite3db
db, err := sql.Open(dbDriverName, dbname)
if err != nil {
fmt.Println(err)
}
//調用函數保存文件到sqlite3數據庫
exceTosqliteChckdata(db, "dly.xlsx")
exceTosqliteNetwl(db, "sx1.xlsx")
time.Sleep(time.Second * 2)
println("數據錄入完成")
}
?
原文鏈接:https://blog.csdn.net/wtt234/article/details/124522353
相關推薦
- 2022-07-11 Python內建屬性getattribute攔截器使用詳解_python
- 2022-12-19 Python?完美解決?Import?“模塊“?could?not?be?resolved?...的
- 2022-11-30 React中常見的TypeScript定義實戰教程_React
- 2023-02-09 Go語言高效編程的3個技巧總結_Golang
- 2021-12-17 element-ui dialog彈窗 點擊空白處使彈窗區不關閉
- 2023-03-20 使用Redis緩存時高效的批量刪除的幾種方案_Redis
- 2023-12-18 MyBatisSystemException異常產生原因及解決方案
- 2023-03-21 Flutter?web?bridge?通信總結分析詳解_Android
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支