date_util.go 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488
  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. }