date_util.go 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663
  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 ConvertLastDayOfMonth(dateText string) (date time.Time, dateStr string, err error) {
  297. // 解析日期
  298. date, err = time.Parse("2006-01", strings.TrimSpace(dateText))
  299. if err != nil {
  300. err = fmt.Errorf("failed to parse date: %v", err)
  301. return
  302. }
  303. // 获取下个月的第一天
  304. nextMonth := date.AddDate(0, 1, 0)
  305. // 获取本月的最后一天
  306. date = nextMonth.AddDate(0, 0, -1)
  307. dateStr = date.Format("2006-01-02")
  308. return
  309. }
  310. func GetLastDayOfMonth(dateText string) (dateStr string, err error) {
  311. // 解析日期
  312. date, err := time.Parse("2006-01", strings.TrimSpace(dateText))
  313. if err != nil {
  314. return "", fmt.Errorf("failed to parse date: %v", err)
  315. }
  316. // 获取下个月的第一天
  317. nextMonth := date.AddDate(0, 1, 0)
  318. // 获取本月的最后一天
  319. lastDay := nextMonth.AddDate(0, 0, -1)
  320. return lastDay.Format("2006-01-02"), nil
  321. }
  322. // ConvertMonthToNumber 时间转换 格式 8月 --> 08
  323. func ConvertMonthToNumber(dateText string) (string, error) {
  324. // 去掉字符串中的 "月"
  325. trimmed := strings.TrimSuffix(strings.TrimSpace(dateText), "月")
  326. // 将月份转换为整数
  327. month, err := strconv.Atoi(trimmed)
  328. if err != nil {
  329. return "", fmt.Errorf("failed to parse month: %v", err)
  330. }
  331. return fmt.Sprintf("%02d", month), nil
  332. }
  333. // 时间转换 格式 1 --> 01
  334. func ConvertMonthToNumber1(dateText string) (string, error) {
  335. // 将月份转换为整数
  336. month, err := strconv.Atoi(dateText)
  337. if err != nil {
  338. return "", fmt.Errorf("failed to parse month: %v", err)
  339. }
  340. return fmt.Sprintf("%02d", month), nil
  341. }
  342. // GetNextThreeMonths 获取传入时间的本月及后两月的年月 2024-08-03 --> 24年8月
  343. func GetNextThreeMonths(dateText string) ([]string, error) {
  344. // 解析日期字符串为时间类型
  345. date, err := time.Parse("2006-01-02", dateText)
  346. if err != nil {
  347. return nil, fmt.Errorf("日期解析错误: %v", err)
  348. }
  349. // 存储结果的切片
  350. var result []string
  351. // 获取本月及后两个月的年份和月份
  352. for i := 0; i < 3; i++ {
  353. year := date.Year() % 100
  354. month := int(date.Month())
  355. // 构建并添加当前年月到结果中
  356. result = append(result, fmt.Sprintf("%d年%d月", year, month))
  357. // 将日期加一个月
  358. date = date.AddDate(0, 1, 0)
  359. }
  360. return result, nil
  361. }
  362. // IsCurrentYear 判断是否是当前年度 传入日期格式为 2023/24年度 --> true, 2024/25年度 --> false
  363. func IsCurrentYear(dateText string) (bool, error) {
  364. // 去掉字符串中的 "年度"
  365. trimmed := strings.TrimSuffix(strings.TrimSpace(dateText), "年度")
  366. // 分割年份,例如 "2023/24" -> ["2023", "24"]
  367. parts := strings.Split(trimmed, "/")
  368. if len(parts) != 2 {
  369. return false, fmt.Errorf("invalid date format: %s", dateText)
  370. }
  371. // 将前一年的年份转换为整数
  372. startYear, err := strconv.Atoi(parts[0])
  373. if err != nil {
  374. return false, fmt.Errorf("failed to parse start year: %v", err)
  375. }
  376. // 获取当前年份
  377. currentYear := time.Now().Year()
  378. // 如果当前年份等于 dateText 中的后一年的年份,返回 true
  379. if currentYear == startYear+1 {
  380. return true, nil
  381. }
  382. return false, nil
  383. }
  384. // GetNextYearLastDay 获取明年本月份的最后一天 2024-08-03 --> 2025-08-31
  385. func GetNextYearLastDay(dateText string) (string, error) {
  386. // 解析日期
  387. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  388. if err != nil {
  389. return "", fmt.Errorf("failed to parse report date: %v", err)
  390. }
  391. // 获取下一年的年份
  392. nextYear := reportDate.Year() + 1
  393. // 获取本月份的最后一天
  394. lastDay := time.Date(nextYear, reportDate.Month()+1, 0, 0, 0, 0, 0, reportDate.Location())
  395. return lastDay.Format("2006-01-02"), nil
  396. }
  397. // GetYearMonth 获取年月日 2024-08-03 --> 2024-08
  398. func GetYearMonth(dateText string) (string, error) {
  399. // 解析日期
  400. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  401. if err != nil {
  402. return "", fmt.Errorf("failed to parse report date: %v", err)
  403. }
  404. return reportDate.Format("2006-01"), nil
  405. }
  406. // GetCurrentMonth 获取当前月份 2024-08-03 --> 8月
  407. func GetCurrentMonth(dateText string) (string, error) {
  408. // 解析日期
  409. reportDate, err := time.Parse("2006-01-02", strings.TrimSpace(dateText))
  410. if err != nil {
  411. return "", fmt.Errorf("failed to parse report date: %v", err)
  412. }
  413. // 计算月份
  414. month := reportDate.Month()
  415. return fmt.Sprintf("%d月", month), nil
  416. }
  417. // GetCurrentYearMonth 获取当前年月 yyyyMM
  418. func GetCurrentYearMonth() string {
  419. // 获取当前时间
  420. now := time.Now()
  421. // 格式化为 "YYYYMM" 形式
  422. yearMonth := now.Format("200601")
  423. return yearMonth
  424. }
  425. // ConvertDateFormat 转换时间格式 MM-dd-yy --> yyyy-MM-dd
  426. func ConvertDateFormat(dataText string) (date time.Time, dateStr string, err error) {
  427. // 定义输入和输出的时间格式
  428. inputFormat := "01-02-06" // MM-dd-yy
  429. outputFormat := "2006-01-02" // yyyy-MM-dd
  430. // 解析输入的日期
  431. date, err = time.ParseInLocation(inputFormat, dataText, time.Local)
  432. if err != nil {
  433. return
  434. }
  435. // 格式化为输出格式
  436. dateStr = date.Format(outputFormat)
  437. return
  438. }
  439. // ConvertDateFormat2 转换时间格式 yyyy-MMQ --> 取每一季度最后一天,例如 2024-01Q --> 2024-03-31
  440. func ConvertDateFormatQuarter(dataText string) (date time.Time, dateStr string, err error) {
  441. // 提取年份和季度信息
  442. yearStr := dataText[:4]
  443. quarterStr := dataText[6:7]
  444. // 转换年份
  445. year, err := strconv.Atoi(yearStr)
  446. if err != nil {
  447. err = fmt.Errorf("无效的年份: %v", err)
  448. return
  449. }
  450. // 根据季度选择最后一天
  451. switch quarterStr {
  452. case "1":
  453. dateStr = fmt.Sprintf("%d-03-31", year)
  454. case "2":
  455. dateStr = fmt.Sprintf("%d-06-30", year)
  456. case "3":
  457. dateStr = fmt.Sprintf("%d-09-30", year)
  458. case "4":
  459. dateStr = fmt.Sprintf("%d-12-31", year)
  460. default:
  461. err = fmt.Errorf("无效的季度: %s", quarterStr)
  462. return
  463. }
  464. // 确保日期格式正确
  465. date, err = time.Parse("2006-01-02", dateStr)
  466. if err != nil {
  467. err = fmt.Errorf("日期解析失败: %v", err)
  468. return
  469. }
  470. return
  471. }
  472. // ConvertDateFormat3 转换时间格式 Jan-23 --> 2023-01-31
  473. func ConvertDateFormatForOSA(dataText string) (date time.Time, dateStr string, err error) {
  474. // 拆分月份和年份
  475. parts := strings.Split(dataText, "-")
  476. if len(parts) != 2 {
  477. err = fmt.Errorf("日期格式不正确")
  478. return
  479. }
  480. // 提取月份和年份
  481. monthStr := parts[0]
  482. yearStr := parts[1]
  483. // 转换年份
  484. year, err := strconv.Atoi(yearStr)
  485. if err != nil {
  486. err = fmt.Errorf("无效的年份: %v", err)
  487. return
  488. }
  489. // 获取月份数字
  490. month, err := time.Parse("Jan", monthStr)
  491. if err != nil {
  492. err = fmt.Errorf("无效的月份: %v", err)
  493. return
  494. }
  495. // 计算最后一天
  496. date = time.Date(year+2000, month.Month()+1, 0, 0, 0, 0, 0, time.UTC) // 直接设置为下个月的第一天,再设为0日得到上个月最后一天
  497. dateStr = date.Format("2006-01-02")
  498. return
  499. }
  500. // ConvertDateFormat4 转换时间格式 2022 --> 2022-12-31
  501. func ConvertDateFormatYear(dataText string) (date time.Time, dateStr string, err error) {
  502. // 解析输入年份
  503. year, err := strconv.Atoi(dataText)
  504. if err != nil {
  505. err = fmt.Errorf("无法解析年份: %v", err)
  506. return
  507. }
  508. // 创建该年最后一天的日期
  509. date = time.Date(year, time.December, 31, 0, 0, 0, 0, time.UTC)
  510. // 返回格式化后的日期字符串
  511. dateStr = date.Format("2006-01-02")
  512. return
  513. }
  514. // ConvertDateFormat5 转换时间格式 yyyy-MM-dd HH:mm:ss --> yyyy-MM-dd
  515. func ConvertDateFormat5(dataText string) (string, error) {
  516. // 解析输入的日期和时间
  517. dateTime, err := time.Parse("2006-01-02 15:04:05", dataText)
  518. if err != nil {
  519. return "", err
  520. }
  521. // 格式化为输出格式
  522. return dateTime.Format("2006-01-02"), nil
  523. }
  524. // ConvertDateFormat6 转换时间格式 2023-March --> 2023-03-31
  525. func ConvertDateFormatForMC(dataText string) (date time.Time, dateStr string, err error) {
  526. // 拆分年份和月份
  527. parts := strings.Split(dataText, "-")
  528. if len(parts) != 2 {
  529. err = fmt.Errorf("日期格式不正确")
  530. return
  531. }
  532. // 提取年份和月份
  533. yearStr := parts[0]
  534. monthStr := parts[1]
  535. // 转换年份
  536. year, err := strconv.Atoi(yearStr)
  537. if err != nil {
  538. err = fmt.Errorf("无效的年份: %v", err)
  539. return
  540. }
  541. // 获取月份数字
  542. month, err := time.Parse("January", monthStr)
  543. if err != nil {
  544. err = fmt.Errorf("无效的月份: %v", err)
  545. return
  546. }
  547. // 获取最后一天
  548. date = time.Date(year, month.Month()+1, 0, 0, 0, 0, 0, time.UTC) // 使用月份数字加1,再设为0日得到上个月最后一天
  549. dateStr = date.Format("2006-01-02")
  550. return
  551. }