date_util.go 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650
  1. // Package utils @Author gmy 2024/8/6 16:06:00
  2. package utils
  3. import (
  4. "fmt"
  5. "strconv"
  6. "strings"
  7. "time"
  8. )
  9. // ParseDateAndWeek parseDateAndWeek 解析日期并计算当前周数 ==> 24年31周
  10. func ParseDateAndWeek(dateText string) (string, error) {
  11. // 解析日期
  12. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(strings.Split(dateText, " ")[0]))
  13. if err != nil {
  14. return "", fmt.Errorf("failed to parse report date: %v", err)
  15. }
  16. // 计算年份和周数
  17. year, week := reportDate.ISOWeek()
  18. // 获取年份的后两位
  19. shortYear := year % 100
  20. targetWeek := fmt.Sprintf("%02d年第%d周", shortYear, week)
  21. return targetWeek, nil
  22. }
  23. // ParseDateAndMonth 解析时间并计算当前月份 和 后两月 1月就是1月F,二月是二月G 规则:F=1月,G=2月,H=3月,J=4月,K=5月,M=6月,N=7月,Q=8月,U=9月,V=10月,X=11月,Z=12月
  24. func ParseDateAndMonth(dateText string) ([]string, error) {
  25. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(strings.Split(dateText, " ")[0]))
  26. if err != nil {
  27. return nil, fmt.Errorf("failed to parse report date: %v", err)
  28. }
  29. months := make([]string, 3)
  30. monthMap := map[string]string{
  31. "01": "1月F",
  32. "02": "2月G",
  33. "03": "3月H",
  34. "04": "4月J",
  35. "05": "5月K",
  36. "06": "6月M",
  37. "07": "7月N",
  38. "08": "8月Q",
  39. "09": "9月X",
  40. "10": "10月X",
  41. "11": "11月X",
  42. "12": "12月Z",
  43. }
  44. for i := 0; i < 3; i++ {
  45. month := reportDate.AddDate(0, i, 0).Format("01")
  46. months[i] = monthMap[month]
  47. }
  48. return months, nil
  49. }
  50. // ParseDateAndMonthColzaOil 油菜籽 进口成本 时间映射
  51. func ParseDateAndMonthColzaOil(dateText string) ([]string, error) {
  52. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(strings.Split(dateText, " ")[0]))
  53. if err != nil {
  54. return nil, fmt.Errorf("failed to parse report date: %v", err)
  55. }
  56. months := make([]string, 3)
  57. monthMap := map[string]string{
  58. "01": "1月F",
  59. "02": "2月H",
  60. "03": "3月H",
  61. "04": "4月K",
  62. "05": "5月K",
  63. "06": "6月N",
  64. "07": "7月N",
  65. "08": "8月X",
  66. "09": "9月X",
  67. "10": "10月X",
  68. "11": "11月X",
  69. "12": "12月F",
  70. }
  71. for i := 0; i < 3; i++ {
  72. month := reportDate.AddDate(0, i, 0).Format("01")
  73. months[i] = monthMap[month]
  74. }
  75. return months, nil
  76. }
  77. // GetCurrentTime 获取当前时间 格式为 2024-08-07 15:29:58
  78. func GetCurrentTime() string {
  79. return time.Now().Format("2006-01-02 15:04:05")
  80. }
  81. // ConvertTimeFormat 转换时间格式 dateText 格式为 2024-08-03 07:53 --> 2024-08-03
  82. func ConvertTimeFormat(dateText string) (string, error) {
  83. // 解析日期
  84. reportDate, err := time.Parse("2006-01-02 15:04", strings.TrimSpace(dateText))
  85. if err != nil {
  86. return "", fmt.Errorf("failed to parse report date: %v", err)
  87. }
  88. return reportDate.Format("2006-01-02"), nil
  89. }
  90. // GetNextThreeMonthsNoYear 获取当前月和后两月 不带年份,转换时间格式 dateText 格式为 2024-08-03 --> 8月,9月,10月
  91. func GetNextThreeMonthsNoYear(dateText string) ([]string, error) {
  92. // 解析日期字符串为时间类型
  93. date, err := time.Parse("2006-01-02", dateText)
  94. if err != nil {
  95. return nil, fmt.Errorf("日期解析错误: %v", err)
  96. }
  97. // 存储结果的切片
  98. var result []string
  99. // 获取本月及后两个月的月份
  100. for i := 0; i < 3; i++ {
  101. month := int(date.Month())
  102. // 构建并添加当前年月到结果中
  103. result = append(result, fmt.Sprintf("%d月", month))
  104. // 将日期加一个月
  105. date = date.AddDate(0, 1, 0)
  106. }
  107. return result, nil
  108. }
  109. // GetNextThreeMonthsLastDay 取当前月的最后一天和后两个月的最后一天 时间格式为 2024-08-03 --> 2024-08-31, 2024-09-30, 2024-10-31
  110. func GetNextThreeMonthsLastDay(dateText string) ([]string, error) {
  111. // 解析日期字符串为时间类型
  112. date, err := time.Parse("2006-01-02", dateText)
  113. if err != nil {
  114. return nil, fmt.Errorf("日期解析错误: %v", err)
  115. }
  116. // 存储结果的切片
  117. var result []string
  118. // 获取本月及后两个月的最后一天
  119. for i := 0; i < 3; i++ {
  120. // 获取下个月的第一天
  121. nextMonth := date.AddDate(0, 1, 0)
  122. // 获取当前月的最后一天
  123. lastDay := nextMonth.AddDate(0, 0, -nextMonth.Day())
  124. // 添加到结果中
  125. result = append(result, lastDay.Format("2006-01-02"))
  126. // 将日期加一个月
  127. date = date.AddDate(0, 1, 0)
  128. }
  129. return result, nil
  130. }
  131. // GetElementInSlice 获取切片中特定的元素,判断传入月份是否在当前切片月份匹配,如果匹配则返回切片中对应的元素 参数格式为 dateTexts month, [2024-08-31, 2024-09-30, 2024-10-31] 08 --> 2024-08-31, 07 --> nil
  132. func GetElementInSlice(dateTexts []string, month string) (string, error) {
  133. for _, dateText := range dateTexts {
  134. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  135. if err != nil {
  136. return "", fmt.Errorf("failed to parse report date: %v", err)
  137. }
  138. if strings.HasSuffix(reportDate.Format("2006-01"), month) {
  139. return dateText, nil
  140. }
  141. }
  142. return "", fmt.Errorf("未找到匹配的月份")
  143. }
  144. // StringToTime string 类型时间转换为 time 类型时间 dateText 格式为 2024-08-03 00:00:00 --> 2024-08-03 00:00:00
  145. func StringToTime(dateText string) (time.Time, error) {
  146. // 解析日期
  147. reportDate, err := time.Parse("2006-01-02 15:04:05", strings.TrimSpace(dateText))
  148. if err != nil {
  149. return time.Time{}, fmt.Errorf("failed to parse report date: %v", err)
  150. }
  151. return reportDate, nil
  152. }
  153. // StringToTimeFormat 转换时间格式 string --> time.Time
  154. func StringToTimeFormat(dateText string, format string) time.Time {
  155. // 解析日期
  156. reportDate, err := time.Parse(format, strings.TrimSpace(dateText))
  157. if err != nil {
  158. return time.Time{}
  159. }
  160. return reportDate
  161. }
  162. // StringToTimeZero string 类型时间转换为 time dateText 格式为 2024-08-03 --> 2024-08-03 00:00:00
  163. func StringToTimeZero(dateText string) (time.Time, error) {
  164. // 解析日期
  165. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  166. if err != nil {
  167. return time.Time{}, fmt.Errorf("failed to parse report date: %v", err)
  168. }
  169. return reportDate, nil
  170. }
  171. // GetWeekdaysInSameWeek 拿到传入时间本周当前工作日的时间列表,时间格式 dataText 格式为 2024-08-03 --> 8月3日
  172. func GetWeekdaysInSameWeek(dateStr string) ([]string, error) {
  173. // 解析输入日期字符串
  174. t, err := time.Parse("2006-01-02", dateStr)
  175. if err != nil {
  176. return nil, err
  177. }
  178. // 获取星期几
  179. weekday := t.Weekday()
  180. // 计算星期一的日期
  181. monday := t.AddDate(0, 0, -int(weekday)+1)
  182. // 生成这周的工作日列表(周一至周五)
  183. var weekdays []string
  184. for i := 0; i < 5; i++ {
  185. day := monday.AddDate(0, 0, i)
  186. weekdays = append(weekdays, fmt.Sprintf("%d月%d日", day.Month(), day.Day()))
  187. }
  188. return weekdays, nil
  189. }
  190. // ConvertToDate 转换后获取当前传入的时间 时间格式为 7月22日 --> 2024-07-22
  191. func ConvertToDate(dateText string) (string, error) {
  192. // 假设当前年份为 2024
  193. currentYear := time.Now().Year()
  194. // 分割日期字符串
  195. parts := strings.Split(dateText, "月")
  196. if len(parts) != 2 {
  197. return "", fmt.Errorf("日期格式错误")
  198. }
  199. // 获取月和日的部分
  200. month, err := strconv.Atoi(parts[0])
  201. if err != nil {
  202. return "", fmt.Errorf("月份解析错误: %v", err)
  203. }
  204. day, err := strconv.Atoi(strings.TrimSuffix(parts[1], "日"))
  205. if err != nil {
  206. return "", fmt.Errorf("日期解析错误: %v", err)
  207. }
  208. // 构建日期
  209. date := time.Date(currentYear, time.Month(month), day, 0, 0, 0, 0, time.Local)
  210. // 格式化为 "2024-07-22"
  211. return date.Format("2006-01-02"), nil
  212. }
  213. // ConvertTimeFormatToYearMonthDay 转换时间格式 dateText 格式为 2024-08-03 --> 24年8月3日
  214. func ConvertTimeFormatToYearMonthDay(dateText string) (string, error) {
  215. // 解析日期
  216. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  217. if err != nil {
  218. return "", fmt.Errorf("failed to parse report date: %v", err)
  219. }
  220. // 获取年份的后两位
  221. shortYear := reportDate.Year() % 100
  222. return fmt.Sprintf("%02d年%d月%d日", shortYear, reportDate.Month(), reportDate.Day()), nil
  223. }
  224. // GetCurrentYearAndLastYear 获取当前年份和前一年的年份 转换时间格式 dateText 格式为 2024-08-03 --> 2024年,2023年
  225. func GetCurrentYearAndLastYear(dateText string) ([]string, error) {
  226. // 解析日期
  227. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  228. if err != nil {
  229. return nil, fmt.Errorf("failed to parse report date: %v", err)
  230. }
  231. years := make([]string, 2)
  232. year := reportDate.Year()
  233. // 当前年份
  234. years[0] = fmt.Sprintf("%d年", year)
  235. // 前一年
  236. years[1] = fmt.Sprintf("%d年", year-1)
  237. return years, nil
  238. }
  239. // ConvertTimeFormatToYearMonth 转换时间格式 dateText 返回本月 和 后两月 格式为 2024-08-03 --> 2024年8月,2024-10-03 --> 2024年10月
  240. func ConvertTimeFormatToYearMonth(dateText string) ([]string, error) {
  241. // 解析日期
  242. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  243. if err != nil {
  244. return nil, fmt.Errorf("failed to parse report date: %v", err)
  245. }
  246. months := make([]string, 3)
  247. for i := 0; i < 3; i++ {
  248. month := reportDate.AddDate(0, i, 0).Format("2006年1月")
  249. months[i] = month
  250. }
  251. return months, nil
  252. }
  253. // GetYearMonthNoYear 获取本月和后两月的年月 2024-08-03 --> 24年8月,24年9月,24年10月
  254. func GetYearMonthNoYear(dateText string) ([]string, error) {
  255. // 解析日期
  256. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  257. if err != nil {
  258. return nil, fmt.Errorf("failed to parse report date: %v", err)
  259. }
  260. months := make([]string, 3)
  261. for i := 0; i < 3; i++ {
  262. month := reportDate.AddDate(0, i, 0).Format("06年1月")
  263. months[i] = month
  264. }
  265. return months, nil
  266. }
  267. // GetCurrentYearAndNextYear 获取当时所在得年度和明年得年度列表 2024-08-03 --> 2023/24年度, 2024/25年度
  268. func GetCurrentYearAndNextYear(dateText string) ([]string, error) {
  269. // 解析日期
  270. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  271. if err != nil {
  272. return nil, fmt.Errorf("failed to parse report date: %v", err)
  273. }
  274. years := make([]string, 2)
  275. year := reportDate.Year()
  276. // 当前年度
  277. years[0] = fmt.Sprintf("%d/%02d年度", year-1, year%100)
  278. // 下一年度
  279. years[1] = fmt.Sprintf("%d/%02d年度", year, (year+1)%100)
  280. return years, nil
  281. }
  282. // IsSameMonth 判断当前传入年月是否是同一月 2024-08-03, 2024-08 --> true, 2024-08-03, 2024-07 --> false
  283. func IsSameMonth(dateText1, dateText2 string) (bool, error) {
  284. // 解析日期
  285. date1, err := time.Parse("2006-01-02", strings.TrimSpace(dateText1))
  286. if err != nil {
  287. return false, fmt.Errorf("failed to parse date1: %v", err)
  288. }
  289. date2, err := time.Parse("2006-01", strings.TrimSpace(dateText2))
  290. if err != nil {
  291. return false, fmt.Errorf("failed to parse date2: %v", err)
  292. }
  293. return date1.Year() == date2.Year() && date1.Month() == date2.Month(), nil
  294. }
  295. // GetLastDayOfMonth 获取传入年月的最后一天 dateText 格式为 2024-08 --> 2024-08-31
  296. func GetLastDayOfMonth(dateText string) (string, error) {
  297. // 解析日期
  298. date, err := time.Parse("2006-01", strings.TrimSpace(dateText))
  299. if err != nil {
  300. return "", fmt.Errorf("failed to parse date: %v", err)
  301. }
  302. // 获取下个月的第一天
  303. nextMonth := date.AddDate(0, 1, 0)
  304. // 获取本月的最后一天
  305. lastDay := nextMonth.AddDate(0, 0, -1)
  306. return lastDay.Format("2006-01-02"), nil
  307. }
  308. // ConvertMonthToNumber 时间转换 格式 8月 --> 08
  309. func ConvertMonthToNumber(dateText string) (string, error) {
  310. // 去掉字符串中的 "月"
  311. trimmed := strings.TrimSuffix(strings.TrimSpace(dateText), "月")
  312. // 将月份转换为整数
  313. month, err := strconv.Atoi(trimmed)
  314. if err != nil {
  315. return "", fmt.Errorf("failed to parse month: %v", err)
  316. }
  317. return fmt.Sprintf("%02d", month), nil
  318. }
  319. // 时间转换 格式 1 --> 01
  320. func ConvertMonthToNumber1(dateText string) (string, error) {
  321. // 将月份转换为整数
  322. month, err := strconv.Atoi(dateText)
  323. if err != nil {
  324. return "", fmt.Errorf("failed to parse month: %v", err)
  325. }
  326. return fmt.Sprintf("%02d", month), nil
  327. }
  328. // GetNextThreeMonths 获取传入时间的本月及后两月的年月 2024-08-03 --> 24年8月
  329. func GetNextThreeMonths(dateText string) ([]string, error) {
  330. // 解析日期字符串为时间类型
  331. date, err := time.Parse("2006-01-02", dateText)
  332. if err != nil {
  333. return nil, fmt.Errorf("日期解析错误: %v", err)
  334. }
  335. // 存储结果的切片
  336. var result []string
  337. // 获取本月及后两个月的年份和月份
  338. for i := 0; i < 3; i++ {
  339. year := date.Year() % 100
  340. month := int(date.Month())
  341. // 构建并添加当前年月到结果中
  342. result = append(result, fmt.Sprintf("%d年%d月", year, month))
  343. // 将日期加一个月
  344. date = date.AddDate(0, 1, 0)
  345. }
  346. return result, nil
  347. }
  348. // IsCurrentYear 判断是否是当前年度 传入日期格式为 2023/24年度 --> true, 2024/25年度 --> false
  349. func IsCurrentYear(dateText string) (bool, error) {
  350. // 去掉字符串中的 "年度"
  351. trimmed := strings.TrimSuffix(strings.TrimSpace(dateText), "年度")
  352. // 分割年份,例如 "2023/24" -> ["2023", "24"]
  353. parts := strings.Split(trimmed, "/")
  354. if len(parts) != 2 {
  355. return false, fmt.Errorf("invalid date format: %s", dateText)
  356. }
  357. // 将前一年的年份转换为整数
  358. startYear, err := strconv.Atoi(parts[0])
  359. if err != nil {
  360. return false, fmt.Errorf("failed to parse start year: %v", err)
  361. }
  362. // 获取当前年份
  363. currentYear := time.Now().Year()
  364. // 如果当前年份等于 dateText 中的后一年的年份,返回 true
  365. if currentYear == startYear+1 {
  366. return true, nil
  367. }
  368. return false, nil
  369. }
  370. // GetNextYearLastDay 获取明年本月份的最后一天 2024-08-03 --> 2025-08-31
  371. func GetNextYearLastDay(dateText string) (string, error) {
  372. // 解析日期
  373. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  374. if err != nil {
  375. return "", fmt.Errorf("failed to parse report date: %v", err)
  376. }
  377. // 获取下一年的年份
  378. nextYear := reportDate.Year() + 1
  379. // 获取本月份的最后一天
  380. lastDay := time.Date(nextYear, reportDate.Month()+1, 0, 0, 0, 0, 0, reportDate.Location())
  381. return lastDay.Format("2006-01-02"), nil
  382. }
  383. // GetYearMonth 获取年月日 2024-08-03 --> 2024-08
  384. func GetYearMonth(dateText string) (string, error) {
  385. // 解析日期
  386. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  387. if err != nil {
  388. return "", fmt.Errorf("failed to parse report date: %v", err)
  389. }
  390. return reportDate.Format("2006-01"), nil
  391. }
  392. // GetCurrentMonth 获取当前月份 2024-08-03 --> 8月
  393. func GetCurrentMonth(dateText string) (string, error) {
  394. // 解析日期
  395. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  396. if err != nil {
  397. return "", fmt.Errorf("failed to parse report date: %v", err)
  398. }
  399. // 计算月份
  400. month := reportDate.Month()
  401. return fmt.Sprintf("%d月", month), nil
  402. }
  403. // GetCurrentYearMonth 获取当前年月 yyyyMM
  404. func GetCurrentYearMonth() string {
  405. // 获取当前时间
  406. now := time.Now()
  407. // 格式化为 "YYYYMM" 形式
  408. yearMonth := now.Format("200601")
  409. return yearMonth
  410. }
  411. // ConvertDateFormat 转换时间格式 MM-dd-yy --> yyyy-MM-dd
  412. func ConvertDateFormat(dataText string) (string, error) {
  413. // 定义输入和输出的时间格式
  414. inputFormat := "01-02-06" // MM-dd-yy
  415. outputFormat := "2006-01-02" // yyyy-MM-dd
  416. // 解析输入的日期
  417. date, err := time.Parse(inputFormat, dataText)
  418. if err != nil {
  419. return "", err
  420. }
  421. // 格式化为输出格式
  422. return date.Format(outputFormat), nil
  423. }
  424. // ConvertDateFormat2 转换时间格式 yyyy-MMQ --> 取每一季度最后一天,例如 2024-01Q --> 2024-03-31
  425. func ConvertDateFormat2(dataText string) (string, error) {
  426. // 提取年份和季度信息
  427. yearStr := dataText[:4]
  428. quarterStr := dataText[6:7]
  429. // 转换年份
  430. year, err := strconv.Atoi(yearStr)
  431. if err != nil {
  432. return "", fmt.Errorf("无效的年份: %v", err)
  433. }
  434. // 根据季度选择最后一天
  435. var endOfQuarter string
  436. switch quarterStr {
  437. case "1":
  438. endOfQuarter = fmt.Sprintf("%d-03-31", year)
  439. case "2":
  440. endOfQuarter = fmt.Sprintf("%d-06-30", year)
  441. case "3":
  442. endOfQuarter = fmt.Sprintf("%d-09-30", year)
  443. case "4":
  444. endOfQuarter = fmt.Sprintf("%d-12-31", year)
  445. default:
  446. return "", fmt.Errorf("无效的季度: %s", quarterStr)
  447. }
  448. // 确保日期格式正确
  449. _, err = time.Parse("2006-01-02", endOfQuarter)
  450. if err != nil {
  451. return "", fmt.Errorf("日期解析失败: %v", err)
  452. }
  453. return endOfQuarter, nil
  454. }
  455. // ConvertDateFormat3 转换时间格式 Jan-23 --> 2023-01-31
  456. func ConvertDateFormat3(dataText string) (string, error) {
  457. // 拆分月份和年份
  458. parts := strings.Split(dataText, "-")
  459. if len(parts) != 2 {
  460. return "", fmt.Errorf("日期格式不正确")
  461. }
  462. // 提取月份和年份
  463. monthStr := parts[0]
  464. yearStr := parts[1]
  465. // 转换年份
  466. year, err := strconv.Atoi(yearStr)
  467. if err != nil {
  468. return "", fmt.Errorf("无效的年份: %v", err)
  469. }
  470. // 获取月份数字
  471. month, err := time.Parse("Jan", monthStr)
  472. if err != nil {
  473. return "", fmt.Errorf("无效的月份: %v", err)
  474. }
  475. // 计算最后一天
  476. lastDay := time.Date(year+2000, month.Month()+1, 0, 0, 0, 0, 0, time.UTC) // 直接设置为下个月的第一天,再设为0日得到上个月最后一天
  477. return lastDay.Format("2006-01-02"), nil
  478. }
  479. // ConvertDateFormat4 转换时间格式 2022 --> 2022-12-31
  480. func ConvertDateFormat4(dataText string) (string, error) {
  481. // 解析输入年份
  482. year, err := strconv.Atoi(dataText)
  483. if err != nil {
  484. return "", fmt.Errorf("无法解析年份: %v", err)
  485. }
  486. // 创建该年最后一天的日期
  487. lastDay := time.Date(year, time.December, 31, 0, 0, 0, 0, time.UTC)
  488. // 返回格式化后的日期字符串
  489. return lastDay.Format("2006-01-02"), nil
  490. }
  491. // ConvertDateFormat5 转换时间格式 yyyy-MM-dd HH:mm:ss --> yyyy-MM-dd
  492. func ConvertDateFormat5(dataText string) (string, error) {
  493. // 解析输入的日期和时间
  494. dateTime, err := time.Parse("2006-01-02 15:04:05", dataText)
  495. if err != nil {
  496. return "", err
  497. }
  498. // 格式化为输出格式
  499. return dateTime.Format("2006-01-02"), nil
  500. }
  501. // ConvertDateFormat6 转换时间格式 2023-March --> 2023-03-31
  502. func ConvertDateFormat6(dataText string) (string, error) {
  503. // 拆分年份和月份
  504. parts := strings.Split(dataText, "-")
  505. if len(parts) != 2 {
  506. return "", fmt.Errorf("日期格式不正确")
  507. }
  508. // 提取年份和月份
  509. yearStr := parts[0]
  510. monthStr := parts[1]
  511. // 转换年份
  512. year, err := strconv.Atoi(yearStr)
  513. if err != nil {
  514. return "", fmt.Errorf("无效的年份: %v", err)
  515. }
  516. // 获取月份数字
  517. month, err := time.Parse("January", monthStr)
  518. if err != nil {
  519. return "", fmt.Errorf("无效的月份: %v", err)
  520. }
  521. // 获取最后一天
  522. lastDay := time.Date(year, month.Month()+1, 0, 0, 0, 0, 0, time.UTC) // 使用月份数字加1,再设为0日得到上个月最后一天
  523. return lastDay.Format("2006-01-02"), nil
  524. }