go 读取excel数据存储到mysql

news/2024/9/22 15:27:03 标签: golang, mysql, 开发语言

一、安装依赖

go get github.com/go-sql-driver/mysql 
go get github.com/jmoiron/sqlx

 

二、main.go

package main

import (
	"fmt"
	"github.com/jmoiron/sqlx"
	"log"
)
import "github.com/tealeg/xlsx"
import _ "github.com/go-sql-driver/mysql"

type Student struct {
	Name string
	Sex  string
}

func (student Student) show() {
	fmt.Printf("Name:%s Sex:%s\r\n", student.Name, student.Sex)
}

func main() {
	excelPath := "students.xlsx"
	xlFile, err := xlsx.OpenFile(excelPath)
	if err != nil {
		fmt.Printf("Error opening Excel file: %s\n", err)
		return
	}
	sheet := xlFile.Sheets[0]
	var students []Student
	i := 0
	for _, row := range sheet.Rows {
		name := row.Cells[0].String()
		sex := row.Cells[1].String()
		fmt.Printf("name:%s sex:%s \r\n", name, sex)
		students = append(students, Student{Name: name, Sex: sex})
		i++
	}
	for _, student := range students {
		student.show()
	}

	/*数据库操作*/
	fmt.Println("数据库操作")
	dsn := "root:123456@tcp(192.168.31.132:3306)/demo"
	db, err := sqlx.Open("mysql", dsn)
	if err != nil {
		log.Fatal(err)
	}

	for i, student := range students {
		if i == 0 {
			continue
		}
		db.NamedExec("insert into students(Name,Sex) values(:name,:sex)", student)
	}

	var studentMaps []*Student
	err = db.Select(&studentMaps, `select name,sex from students where name=?`, "张三")
	if err != nil {
		log.Fatal(err)
	}
	for _, student := range studentMaps {
		student.show()
	}
}


http://www.niftyadmin.cn/n/5670490.html

相关文章

ollama设置开机启动服务

在 Ubuntu 20.04 系统中创建一个 systemd 服务文件以管理一个名为 ollama 的自定义服务,您需要遵循以下步骤: 打开终端。创建一个新的服务文件 /etc/systemd/system/ollama.service。 下面是一个基本的 ollama.service 文件示例。您需要根据您的服务需求…

华为全联接大会HC2024 观会感

9/19-21于上海,华为举办了他一年一届也是最重要的华为系展会-Huawei Connect 华为全联接大会,今天有幸赶在展会最后一天来参观一下 上午照常是keynote,由华为计算线总裁进行了今天的KN开场,介绍了华为在“算”方面的进展&#x…

华为为什么要做三折叠屏手机?

前些天我做了一条视频,关于讲华W的新的三折叠屏手机。我说我有点失望,结果引起了华W的同事的一些关注。于是,华W几位高管都跑过来,跟我解释为什么会出现这样的一个状态。 我才知道,这款手机他们其实是亏着钱在卖的。因…

find命令详解

find 命令详解 find 命令是 Unix/Linux 系统中功能强大且灵活的工具,用于在目录结构中搜索文件和目录。它不仅能够根据文件名、类型、大小、修改时间等属性进行搜索,还可以执行对搜索结果的操作,如删除、移动、复制等。本文将详细阐述 find …

探索IT行业中的职业发展路径

探索IT行业中的职业发展路径 IT行业近年来备受瞩目,成为众多职场人梦寐以求的职业领域。无论是程序开发、网络安全、运维管理,还是数据科学与人工智能,每个分支都充满了机遇与挑战。今天我将分享一些关于IT行业中常见的职业发展路径&#xf…

Google 扩展 Chrome 安全和隐私功能

过去一周,谷歌一直在推出新特性和功能,旨在让用户在 Chrome 上的桌面体验更加安全,最新的举措是扩展在多个设备上保存密钥的功能。 到目前为止,Chrome 网络用户只能将密钥保存到 Android 上的 Google 密码管理器,然后…

C语言PTA-计算最大游戏胜率

计算最大游戏胜率 游戏中心新出了一种游戏,名叫“三连胜”,规则很简单:首先从三场比赛中选出任何一场,然后对于每一个选定的比赛,猜三个可能的结果中的一个——即W代表赢,T代表平,L代表输。每个…

三菱FX3U-4DA(4通道模拟量输出)使用说明

FX3U-4DA连接在FX3G/FX3GC/FX3U/FX3UC可编程控制器上,是将来自可编程控制器的4个通道的数字值转换成模拟量值(电压/电流)并输出的模拟量特殊功能模块。 1、FX3G/FX3GC/FX3U/FX3UC可编程控制器上最多可以连接8台*1(包括其它特殊功能模块的连接台数。) 2、可以对各通道…