date_util.go 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639
  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. // StringToTimeZero string 类型时间转换为 time dateText 格式为 2024-08-03 --> 2024-08-03 00:00:00
  154. func StringToTimeZero(dateText string) (time.Time, error) {
  155. // 解析日期
  156. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  157. if err != nil {
  158. return time.Time{}, fmt.Errorf("failed to parse report date: %v", err)
  159. }
  160. return reportDate, nil
  161. }
  162. // GetWeekdaysInSameWeek 拿到传入时间本周当前工作日的时间列表,时间格式 dataText 格式为 2024-08-03 --> 8月3日
  163. func GetWeekdaysInSameWeek(dateStr string) ([]string, error) {
  164. // 解析输入日期字符串
  165. t, err := time.Parse("2006-01-02", dateStr)
  166. if err != nil {
  167. return nil, err
  168. }
  169. // 获取星期几
  170. weekday := t.Weekday()
  171. // 计算星期一的日期
  172. monday := t.AddDate(0, 0, -int(weekday)+1)
  173. // 生成这周的工作日列表(周一至周五)
  174. var weekdays []string
  175. for i := 0; i < 5; i++ {
  176. day := monday.AddDate(0, 0, i)
  177. weekdays = append(weekdays, fmt.Sprintf("%d月%d日", day.Month(), day.Day()))
  178. }
  179. return weekdays, nil
  180. }
  181. // ConvertToDate 转换后获取当前传入的时间 时间格式为 7月22日 --> 2024-07-22
  182. func ConvertToDate(dateText string) (string, error) {
  183. // 假设当前年份为 2024
  184. currentYear := time.Now().Year()
  185. // 分割日期字符串
  186. parts := strings.Split(dateText, "月")
  187. if len(parts) != 2 {
  188. return "", fmt.Errorf("日期格式错误")
  189. }
  190. // 获取月和日的部分
  191. month, err := strconv.Atoi(parts[0])
  192. if err != nil {
  193. return "", fmt.Errorf("月份解析错误: %v", err)
  194. }
  195. day, err := strconv.Atoi(strings.TrimSuffix(parts[1], "日"))
  196. if err != nil {
  197. return "", fmt.Errorf("日期解析错误: %v", err)
  198. }
  199. // 构建日期
  200. date := time.Date(currentYear, time.Month(month), day, 0, 0, 0, 0, time.Local)
  201. // 格式化为 "2024-07-22"
  202. return date.Format("2006-01-02"), nil
  203. }
  204. // ConvertTimeFormatToYearMonthDay 转换时间格式 dateText 格式为 2024-08-03 --> 24年8月3日
  205. func ConvertTimeFormatToYearMonthDay(dateText string) (string, error) {
  206. // 解析日期
  207. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  208. if err != nil {
  209. return "", fmt.Errorf("failed to parse report date: %v", err)
  210. }
  211. // 获取年份的后两位
  212. shortYear := reportDate.Year() % 100
  213. return fmt.Sprintf("%02d年%d月%d日", shortYear, reportDate.Month(), reportDate.Day()), nil
  214. }
  215. // GetCurrentYearAndLastYear 获取当前年份和前一年的年份 转换时间格式 dateText 格式为 2024-08-03 --> 2024年,2023年
  216. func GetCurrentYearAndLastYear(dateText string) ([]string, error) {
  217. // 解析日期
  218. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  219. if err != nil {
  220. return nil, fmt.Errorf("failed to parse report date: %v", err)
  221. }
  222. years := make([]string, 2)
  223. year := reportDate.Year()
  224. // 当前年份
  225. years[0] = fmt.Sprintf("%d年", year)
  226. // 前一年
  227. years[1] = fmt.Sprintf("%d年", year-1)
  228. return years, nil
  229. }
  230. // ConvertTimeFormatToYearMonth 转换时间格式 dateText 返回本月 和 后两月 格式为 2024-08-03 --> 2024年8月,2024-10-03 --> 2024年10月
  231. func ConvertTimeFormatToYearMonth(dateText string) ([]string, error) {
  232. // 解析日期
  233. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  234. if err != nil {
  235. return nil, fmt.Errorf("failed to parse report date: %v", err)
  236. }
  237. months := make([]string, 3)
  238. for i := 0; i < 3; i++ {
  239. month := reportDate.AddDate(0, i, 0).Format("2006年1月")
  240. months[i] = month
  241. }
  242. return months, nil
  243. }
  244. // GetYearMonthNoYear 获取本月和后两月的年月 2024-08-03 --> 24年8月,24年9月,24年10月
  245. func GetYearMonthNoYear(dateText string) ([]string, error) {
  246. // 解析日期
  247. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  248. if err != nil {
  249. return nil, fmt.Errorf("failed to parse report date: %v", err)
  250. }
  251. months := make([]string, 3)
  252. for i := 0; i < 3; i++ {
  253. month := reportDate.AddDate(0, i, 0).Format("06年1月")
  254. months[i] = month
  255. }
  256. return months, nil
  257. }
  258. // GetCurrentYearAndNextYear 获取当时所在得年度和明年得年度列表 2024-08-03 --> 2023/24年度, 2024/25年度
  259. func GetCurrentYearAndNextYear(dateText string) ([]string, error) {
  260. // 解析日期
  261. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  262. if err != nil {
  263. return nil, fmt.Errorf("failed to parse report date: %v", err)
  264. }
  265. years := make([]string, 2)
  266. year := reportDate.Year()
  267. // 当前年度
  268. years[0] = fmt.Sprintf("%d/%02d年度", year-1, year%100)
  269. // 下一年度
  270. years[1] = fmt.Sprintf("%d/%02d年度", year, (year+1)%100)
  271. return years, nil
  272. }
  273. // IsSameMonth 判断当前传入年月是否是同一月 2024-08-03, 2024-08 --> true, 2024-08-03, 2024-07 --> false
  274. func IsSameMonth(dateText1, dateText2 string) (bool, error) {
  275. // 解析日期
  276. date1, err := time.Parse("2006-01-02", strings.TrimSpace(dateText1))
  277. if err != nil {
  278. return false, fmt.Errorf("failed to parse date1: %v", err)
  279. }
  280. date2, err := time.Parse("2006-01", strings.TrimSpace(dateText2))
  281. if err != nil {
  282. return false, fmt.Errorf("failed to parse date2: %v", err)
  283. }
  284. return date1.Year() == date2.Year() && date1.Month() == date2.Month(), nil
  285. }
  286. // GetLastDayOfMonth 获取传入年月的最后一天 dateText 格式为 2024-08 --> 2024-08-31
  287. func GetLastDayOfMonth(dateText string) (string, error) {
  288. // 解析日期
  289. date, err := time.Parse("2006-01", strings.TrimSpace(dateText))
  290. if err != nil {
  291. return "", fmt.Errorf("failed to parse date: %v", err)
  292. }
  293. // 获取下个月的第一天
  294. nextMonth := date.AddDate(0, 1, 0)
  295. // 获取本月的最后一天
  296. lastDay := nextMonth.AddDate(0, 0, -1)
  297. return lastDay.Format("2006-01-02"), nil
  298. }
  299. // ConvertMonthToNumber 时间转换 格式 8月 --> 08
  300. func ConvertMonthToNumber(dateText string) (string, error) {
  301. // 去掉字符串中的 "月"
  302. trimmed := strings.TrimSuffix(strings.TrimSpace(dateText), "月")
  303. // 将月份转换为整数
  304. month, err := strconv.Atoi(trimmed)
  305. if err != nil {
  306. return "", fmt.Errorf("failed to parse month: %v", err)
  307. }
  308. return fmt.Sprintf("%02d", month), nil
  309. }
  310. // 时间转换 格式 1 --> 01
  311. func ConvertMonthToNumber1(dateText string) (string, error) {
  312. // 将月份转换为整数
  313. month, err := strconv.Atoi(dateText)
  314. if err != nil {
  315. return "", fmt.Errorf("failed to parse month: %v", err)
  316. }
  317. return fmt.Sprintf("%02d", month), nil
  318. }
  319. // GetNextThreeMonths 获取传入时间的本月及后两月的年月 2024-08-03 --> 24年8月
  320. func GetNextThreeMonths(dateText string) ([]string, error) {
  321. // 解析日期字符串为时间类型
  322. date, err := time.Parse("2006-01-02", dateText)
  323. if err != nil {
  324. return nil, fmt.Errorf("日期解析错误: %v", err)
  325. }
  326. // 存储结果的切片
  327. var result []string
  328. // 获取本月及后两个月的年份和月份
  329. for i := 0; i < 3; i++ {
  330. year := date.Year() % 100
  331. month := int(date.Month())
  332. // 构建并添加当前年月到结果中
  333. result = append(result, fmt.Sprintf("%d年%d月", year, month))
  334. // 将日期加一个月
  335. date = date.AddDate(0, 1, 0)
  336. }
  337. return result, nil
  338. }
  339. // IsCurrentYear 判断是否是当前年度 传入日期格式为 2023/24年度 --> true, 2024/25年度 --> false
  340. func IsCurrentYear(dateText string) (bool, error) {
  341. // 去掉字符串中的 "年度"
  342. trimmed := strings.TrimSuffix(strings.TrimSpace(dateText), "年度")
  343. // 分割年份,例如 "2023/24" -> ["2023", "24"]
  344. parts := strings.Split(trimmed, "/")
  345. if len(parts) != 2 {
  346. return false, fmt.Errorf("invalid date format: %s", dateText)
  347. }
  348. // 将前一年的年份转换为整数
  349. startYear, err := strconv.Atoi(parts[0])
  350. if err != nil {
  351. return false, fmt.Errorf("failed to parse start year: %v", err)
  352. }
  353. // 获取当前年份
  354. currentYear := time.Now().Year()
  355. // 如果当前年份等于 dateText 中的后一年的年份,返回 true
  356. if currentYear == startYear+1 {
  357. return true, nil
  358. }
  359. return false, nil
  360. }
  361. // GetNextYearLastDay 获取明年本月份的最后一天 2024-08-03 --> 2025-08-31
  362. func GetNextYearLastDay(dateText string) (string, error) {
  363. // 解析日期
  364. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  365. if err != nil {
  366. return "", fmt.Errorf("failed to parse report date: %v", err)
  367. }
  368. // 获取下一年的年份
  369. nextYear := reportDate.Year() + 1
  370. // 获取本月份的最后一天
  371. lastDay := time.Date(nextYear, reportDate.Month()+1, 0, 0, 0, 0, 0, reportDate.Location())
  372. return lastDay.Format("2006-01-02"), nil
  373. }
  374. // GetYearMonth 获取年月日 2024-08-03 --> 2024-08
  375. func GetYearMonth(dateText string) (string, error) {
  376. // 解析日期
  377. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  378. if err != nil {
  379. return "", fmt.Errorf("failed to parse report date: %v", err)
  380. }
  381. return reportDate.Format("2006-01"), nil
  382. }
  383. // GetCurrentMonth 获取当前月份 2024-08-03 --> 8月
  384. func GetCurrentMonth(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. // 计算月份
  391. month := reportDate.Month()
  392. return fmt.Sprintf("%d月", month), nil
  393. }
  394. // GetCurrentYearMonth 获取当前年月 yyyyMM
  395. func GetCurrentYearMonth() string {
  396. // 获取当前时间
  397. now := time.Now()
  398. // 格式化为 "YYYYMM" 形式
  399. yearMonth := now.Format("200601")
  400. return yearMonth
  401. }
  402. // ConvertDateFormat 转换时间格式 MM-dd-yy --> yyyy-MM-dd
  403. func ConvertDateFormat(dataText string) (string, error) {
  404. // 定义输入和输出的时间格式
  405. inputFormat := "01-02-06" // MM-dd-yy
  406. outputFormat := "2006-01-02" // yyyy-MM-dd
  407. // 解析输入的日期
  408. date, err := time.Parse(inputFormat, dataText)
  409. if err != nil {
  410. return "", err
  411. }
  412. // 格式化为输出格式
  413. return date.Format(outputFormat), nil
  414. }
  415. // ConvertDateFormat2 转换时间格式 yyyy-MMQ --> 取每一季度最后一天,例如 2024-01Q --> 2024-03-31
  416. func ConvertDateFormat2(dataText string) (string, error) {
  417. // 提取年份和季度信息
  418. yearStr := dataText[:4]
  419. quarterStr := dataText[6:7]
  420. // 转换年份
  421. year, err := strconv.Atoi(yearStr)
  422. if err != nil {
  423. return "", fmt.Errorf("无效的年份: %v", err)
  424. }
  425. // 根据季度选择最后一天
  426. var endOfQuarter string
  427. switch quarterStr {
  428. case "1":
  429. endOfQuarter = fmt.Sprintf("%d-03-31", year)
  430. case "2":
  431. endOfQuarter = fmt.Sprintf("%d-06-30", year)
  432. case "3":
  433. endOfQuarter = fmt.Sprintf("%d-09-30", year)
  434. case "4":
  435. endOfQuarter = fmt.Sprintf("%d-12-31", year)
  436. default:
  437. return "", fmt.Errorf("无效的季度: %s", quarterStr)
  438. }
  439. // 确保日期格式正确
  440. _, err = time.Parse("2006-01-02", endOfQuarter)
  441. if err != nil {
  442. return "", fmt.Errorf("日期解析失败: %v", err)
  443. }
  444. return endOfQuarter, nil
  445. }
  446. // ConvertDateFormat3 转换时间格式 Jan-23 --> 2023-01-31
  447. func ConvertDateFormat3(dataText string) (string, error) {
  448. // 拆分月份和年份
  449. parts := strings.Split(dataText, "-")
  450. if len(parts) != 2 {
  451. return "", fmt.Errorf("日期格式不正确")
  452. }
  453. // 提取月份和年份
  454. monthStr := parts[0]
  455. yearStr := parts[1]
  456. // 转换年份
  457. year, err := strconv.Atoi(yearStr)
  458. if err != nil {
  459. return "", fmt.Errorf("无效的年份: %v", err)
  460. }
  461. // 获取月份数字
  462. month, err := time.Parse("Jan", monthStr)
  463. if err != nil {
  464. return "", fmt.Errorf("无效的月份: %v", err)
  465. }
  466. // 计算最后一天
  467. lastDay := time.Date(year+2000, month.Month()+1, 0, 0, 0, 0, 0, time.UTC) // 直接设置为下个月的第一天,再设为0日得到上个月最后一天
  468. return lastDay.Format("2006-01-02"), nil
  469. }
  470. // ConvertDateFormat4 转换时间格式 2022 --> 2022-12-31
  471. func ConvertDateFormat4(dataText string) (string, error) {
  472. // 解析输入年份
  473. year, err := strconv.Atoi(dataText)
  474. if err != nil {
  475. return "", fmt.Errorf("无法解析年份: %v", err)
  476. }
  477. // 创建该年最后一天的日期
  478. lastDay := time.Date(year, time.December, 31, 0, 0, 0, 0, time.UTC)
  479. // 返回格式化后的日期字符串
  480. return lastDay.Format("2006-01-02"), nil
  481. }
  482. // ConvertDateFormat5 转换时间格式 yyyy-MM-dd HH:mm:ss --> yyyy-MM-dd
  483. func ConvertDateFormat5(dataText string) (string, error) {
  484. // 解析输入的日期和时间
  485. dateTime, err := time.Parse("2006-01-02 15:04:05", dataText)
  486. if err != nil {
  487. return "", err
  488. }
  489. // 格式化为输出格式
  490. return dateTime.Format("2006-01-02"), nil
  491. }
  492. // ConvertDateFormat6 转换时间格式 2023-March --> 2023-03-31
  493. func ConvertDateFormat6(dataText string) (string, error) {
  494. // 拆分年份和月份
  495. parts := strings.Split(dataText, "-")
  496. if len(parts) != 2 {
  497. return "", fmt.Errorf("日期格式不正确")
  498. }
  499. // 提取年份和月份
  500. yearStr := parts[0]
  501. monthStr := parts[1]
  502. // 转换年份
  503. year, err := strconv.Atoi(yearStr)
  504. if err != nil {
  505. return "", fmt.Errorf("无效的年份: %v", err)
  506. }
  507. // 获取月份数字
  508. month, err := time.Parse("January", monthStr)
  509. if err != nil {
  510. return "", fmt.Errorf("无效的月份: %v", err)
  511. }
  512. // 获取最后一天
  513. lastDay := time.Date(year, month.Month()+1, 0, 0, 0, 0, 0, time.UTC) // 使用月份数字加1,再设为0日得到上个月最后一天
  514. return lastDay.Format("2006-01-02"), nil
  515. }