数据清洗:Golang规范日期格式

在做数据导入的时候,由于输入人员多和随意(大多数是审美不同),导致数据格式五花八门,就一个日期列,就会出现下面这些样式的:

  • 2023.02.03
  • 2023/02/03
  • 2023.2.3
  • 2023/2/3
  • 2023年2月3日
  • 2023年2月3日上午
  • 2023-02-03

大体就这么多样式,跟多的,就是中间有些空格。

为了达到统一的数据美,需要一个函数,把所有样式的,都统一成 2023-02-03 这样的。

Go 复制代码
func HandleData(date string) string {
	date = strings.TrimSpace(date)
	date = strings.ReplaceAll(date, ".", "-")
	date = strings.ReplaceAll(date, "/", "-")
	date = strings.ReplaceAll(date, "年", "-")
	date = strings.ReplaceAll(date, "月", "-")
	date = strings.ReplaceAll(date, "日", "")
	date = strings.ReplaceAll(date, "上午", "")
	date = strings.ReplaceAll(date, "下午", "")

	year := date[0:4]
	tmp := date[5:]
	m := tmp[:strings.Index(tmp, "-")]
	d := tmp[strings.Index(tmp, "-")+1:]
	// fmt.Println(year, m, d)

	m = strings.ReplaceAll(m, " ", "")
	d = strings.ReplaceAll(d, " ", "")
	if len(m) == 1 {
		m = "0" + m
	}
	if len(d) == 1 {
		d = "0" + d
	}
	return year + "-" + m + "-" + d
}
相关推荐
l1t8 分钟前
JIT执行python脚本的工具codon安装和测试
开发语言·python
空山返景28 分钟前
Dify RAG知识库-自部署完整指南
后端
程似锦吖29 分钟前
无中生有 之 从0开始写一个动态定时任务管理
java·开发语言
苏三的开发日记1 小时前
如何规避死锁
后端
该用户已不存在1 小时前
用 Claude Code Agents 与 CI/CD 搭建自动化研发团队(Part 3)
后端·ai编程·claude
豹哥学前端1 小时前
agent智能体经典范式构建
人工智能·后端
Dxy12393102161 小时前
Python 去除 HTML 标签获取纯文本
开发语言·python·html
洛的地理研学1 小时前
Python下载并处理MOD13A3植被指数数据
开发语言·python
humcomm1 小时前
Java 新特性2026年5月速览
java·开发语言
xiao_li_ya1 小时前
C++学习日记1(`*`的理解、const关键词)
开发语言·c++