week.go 38 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282
  1. package base_from_yongyi
  2. import (
  3. "eta/eta_data_analysis/models"
  4. "eta/eta_data_analysis/utils"
  5. "fmt"
  6. "github.com/tealeg/xlsx"
  7. "strconv"
  8. "strings"
  9. "time"
  10. )
  11. var YongyiWeeklySheetMap5 map[string]*models.YongyiSheet
  12. var YongyiWeeklySheetMap6 map[string]*models.YongyiSheet
  13. var YongyiWeeklySheetMap9 map[string]*models.YongyiSheet
  14. func init() {
  15. YongyiWeeklySheetMap5 = map[string]*models.YongyiSheet{
  16. "周度-50公斤二元母猪价格": {"50公斤二元母猪价格", "周度-50公斤二元母猪价格", "周度", "元/头"},
  17. "周度-规模场15公斤仔猪出栏价": {"规模场15公斤仔猪出栏价", "周度-规模场15公斤仔猪出栏价", "周度", "元/头"},
  18. "周度-宰后结算价": {"宰后结算价", "周度-宰后结算价", "周度", "元/公斤"},
  19. "周度-冻品库存": {"冻品库存", "周度-冻品库存", "周度", "%"},
  20. "周度-猪肉价(前三等级白条均价)": {"前三等级白条均价", "周度-猪肉价(前三等级白条均价)", "周度", "元/公斤"},
  21. }
  22. YongyiWeeklySheetMap6 = map[string]*models.YongyiSheet{
  23. "周度-冻品库存多样本": {"冻品库存多样本", "周度-冻品库存多样本", "周度", "%"},
  24. "月度出栏完成率": {"出栏完成率", "月度出栏完成率", "旬度", "%"},
  25. }
  26. YongyiWeeklySheetMap9 = map[string]*models.YongyiSheet{
  27. "月度-小猪存栏(2020年5月新增)": {"50kg以下小猪存栏量", "月度-小猪存栏(2020年5月新增)", "月度", "头"},
  28. "月度-中猪存栏(2020年5月新增)": {"中猪存栏量", "月度-中猪存栏(2020年5月新增)", "月度", "头"},
  29. "月度-大猪存栏(2020年5月新增)": {"大猪存栏量", "月度-大猪存栏(2020年5月新增)", "月度", "头"},
  30. }
  31. }
  32. type ExcelDateRecordFirst struct {
  33. Date time.Time `xlsx:"0"`
  34. }
  35. type ExcelDateRecord struct {
  36. Date time.Time `xlsx:"1"`
  37. }
  38. // HandleYongyiExcelWeekly1 周度-商品猪出栏价
  39. func HandleYongyiExcelWeekly1(sheet *xlsx.Sheet) (indexList []*models.YongyiExcelIndex, err error) {
  40. classifyName := "周度-商品猪出栏价"
  41. classifyMap := getClassifySortMap()
  42. classifySort, _ := classifyMap[classifyName]
  43. frequency := "周度"
  44. unit := "元/公斤"
  45. namePrefix := "商品猪出栏价"
  46. namePrefixPingin := "yyzx" + utils.GetFirstPingYin(namePrefix)
  47. // 遍历行读取
  48. indexList = make([]*models.YongyiExcelIndex, 0)
  49. areaMap := make(map[int]string)
  50. provinceMap := make(map[int]string)
  51. maxRow := sheet.MaxRow
  52. sort := 0
  53. fmt.Println("最大行")
  54. fmt.Println(maxRow)
  55. // 指标名称
  56. indexMap := make(map[string]*models.YongyiExcelIndex)
  57. for i := 0; i < maxRow; i++ {
  58. fmt.Printf("当前第%d行 \n", i)
  59. if i == 0 { // 首行,表示时间
  60. row := sheet.Row(i)
  61. cells := row.Cells
  62. for k, cell := range cells {
  63. text := cell.String()
  64. if k > 1 && text != "" {
  65. // 检查单元格是否为合并单元格
  66. if cell.HMerge > 0 {
  67. for j := 1; j <= cell.HMerge; j++ {
  68. areaMap[k+j] = text
  69. }
  70. }
  71. if cell.VMerge > 0 {
  72. provinceMap[k] = text
  73. }
  74. areaMap[k] = text
  75. }
  76. }
  77. } else if i == 1 { //表示表头
  78. // 处理 index指标表
  79. row := sheet.Row(i)
  80. cells := row.Cells
  81. for k, cell := range cells {
  82. text := cell.String()
  83. if text != "" {
  84. provinceMap[k] = text
  85. }
  86. }
  87. } else { //数据列
  88. row := sheet.Row(i)
  89. cells := row.Cells
  90. date := ""
  91. for k, cell := range cells {
  92. fmt.Printf("当前第%d列 \n", k)
  93. text := cell.String()
  94. if k == 0 {
  95. continue
  96. } else if k == 1 {
  97. tmpRow := row
  98. r := &ExcelDateRecord{}
  99. if e := tmpRow.ReadStruct(r); e != nil {
  100. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 读取行,时间列失败 Err:%s", sheet.Name, i, k, e))
  101. continue
  102. }
  103. date = r.Date.Format(utils.FormatDate)
  104. fmt.Println(date)
  105. continue
  106. } else {
  107. if text == "" {
  108. continue
  109. }
  110. if strings.Contains(text, "%") {
  111. text = strings.Replace(text, "%", "", 1)
  112. }
  113. _, e := strconv.ParseFloat(text, 64)
  114. if e != nil {
  115. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 strconv.ParseFloat Err:%s", sheet.Name, i, k, e))
  116. continue
  117. }
  118. }
  119. area, ok1 := areaMap[k]
  120. if !ok1 {
  121. err = fmt.Errorf("找不到对应的区域,第%d行,第%d列", i, k)
  122. return
  123. }
  124. province, ok2 := provinceMap[k]
  125. if !ok2 {
  126. err = fmt.Errorf("找不到对应的列名,第%d行,第%d列", i, k)
  127. return
  128. }
  129. fmt.Printf("当前第%d行第%d列, 当前省份%s \n", i, k, province)
  130. // 处理指标名称
  131. fullIndexName := fmt.Sprintf("%s/%s/%s", namePrefix, area, province)
  132. provincePingyin := utils.GetFullPingYin(province)
  133. areaPingin := utils.GetFirstPingYin(area)
  134. fullIndexNamePingyin := namePrefixPingin + areaPingin + provincePingyin
  135. if province == "全 国1" || province == "全 国2" || province == "全国1" || province == "全国2" {
  136. province = strings.ReplaceAll(province, " ", "")
  137. fullIndexName = fmt.Sprintf("%s/%s", namePrefix, province)
  138. fullIndexNamePingyin = namePrefixPingin + provincePingyin
  139. }
  140. indexItem, okIndex := indexMap[fullIndexName]
  141. if !okIndex {
  142. // 新增指标
  143. indexItem = new(models.YongyiExcelIndex)
  144. indexItem.IndexName = fullIndexName
  145. indexItem.ClassifyName = classifyName
  146. indexItem.ClassifySort = classifySort
  147. indexItem.IndexCode = fullIndexNamePingyin
  148. indexItem.Frequency = frequency
  149. indexItem.Sort = sort
  150. indexItem.Unit = unit
  151. indexItem.ExcelDataMap = make(map[string]string)
  152. sort++
  153. }
  154. fmt.Printf("indexItem%s", indexItem.IndexCode)
  155. indexItem.ExcelDataMap[date] = text
  156. indexMap[fullIndexName] = indexItem
  157. continue
  158. }
  159. }
  160. }
  161. for _, v := range indexMap {
  162. indexList = append(indexList, v)
  163. }
  164. return
  165. }
  166. // HandleYongyiExcelWeekly2 周度-体重
  167. func HandleYongyiExcelWeekly2(sheet *xlsx.Sheet) (indexList []*models.YongyiExcelIndex, err error) {
  168. classifyName := "周度-体重"
  169. classifyMap := getClassifySortMap()
  170. classifySort, _ := classifyMap[classifyName]
  171. frequency := "周度"
  172. unit := "公斤"
  173. namePrefix := "商品猪出栏体重"
  174. namePrefixPingin := "yyzx" + utils.GetFirstPingYin(namePrefix)
  175. // 遍历行读取
  176. indexList = make([]*models.YongyiExcelIndex, 0)
  177. areaMap := make(map[int]string)
  178. provinceMap := make(map[int]string)
  179. maxRow := sheet.MaxRow
  180. sort := 0
  181. fmt.Println("最大行")
  182. fmt.Println(maxRow)
  183. // 指标名称
  184. indexMap := make(map[string]*models.YongyiExcelIndex)
  185. for i := 0; i < maxRow; i++ {
  186. fmt.Printf("当前第%d行 \n", i)
  187. if i == 0 { // 首行,表示时间
  188. row := sheet.Row(i)
  189. cells := row.Cells
  190. for k, cell := range cells {
  191. text := cell.String()
  192. if k > 2 && text != "" {
  193. // 检查单元格是否为合并单元格
  194. if cell.HMerge > 0 {
  195. for j := 1; j <= cell.HMerge; j++ {
  196. areaMap[k+j] = text
  197. }
  198. }
  199. if cell.VMerge > 0 {
  200. provinceMap[k] = text
  201. }
  202. areaMap[k] = text
  203. }
  204. }
  205. } else if i == 1 { //表示表头
  206. // 处理 index指标表
  207. row := sheet.Row(i)
  208. cells := row.Cells
  209. for k, cell := range cells {
  210. text := cell.String()
  211. if text != "" {
  212. provinceMap[k] = text
  213. }
  214. }
  215. } else { //数据列
  216. row := sheet.Row(i)
  217. cells := row.Cells
  218. date := ""
  219. name := ""
  220. for k, cell := range cells {
  221. fmt.Printf("当前第%d列 \n", k)
  222. text := cell.String()
  223. if k == 0 {
  224. continue
  225. } else if k == 1 {
  226. tmpRow := row
  227. r := &ExcelDateRecord{}
  228. if e := tmpRow.ReadStruct(r); e != nil {
  229. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 读取行,时间列失败 Err:%s", sheet.Name, i, k, e))
  230. continue
  231. }
  232. date = r.Date.Format(utils.FormatDate)
  233. fmt.Println(date)
  234. continue
  235. } else if k == 2 {
  236. name = text
  237. continue
  238. } else {
  239. // 判断出不是字符的,则过滤
  240. if text == "" {
  241. continue
  242. }
  243. if strings.Contains(text, "%") {
  244. text = strings.Replace(text, "%", "", 1)
  245. }
  246. _, e := strconv.ParseFloat(text, 64)
  247. if e != nil {
  248. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 strconv.ParseFloat Err:%s", sheet.Name, i, k, e))
  249. continue
  250. }
  251. }
  252. area, ok1 := areaMap[k]
  253. if !ok1 {
  254. err = fmt.Errorf("找不到对应的区域,第%d行,第%d列", i, k)
  255. return
  256. }
  257. province, ok2 := provinceMap[k]
  258. if !ok2 {
  259. err = fmt.Errorf("找不到对应的列名,第%d行,第%d列", i, k)
  260. return
  261. }
  262. fmt.Printf("当前第%d行第%d列, 当前省份%s \n", i, k, province)
  263. // 处理指标名称
  264. fullIndexName := fmt.Sprintf("%s/%s/%s/%s", namePrefix, area, province, name)
  265. provincePingyin := utils.GetFullPingYin(province)
  266. areaPingin := utils.GetFirstPingYin(area)
  267. namePingin := utils.GetFirstPingYin(name)
  268. fullIndexNamePingyin := namePrefixPingin + areaPingin + provincePingyin + namePingin
  269. if province == "全 国1" || province == "全 国2" || province == "全国1" || province == "全国2" {
  270. province = strings.ReplaceAll(province, " ", "")
  271. fullIndexName = fmt.Sprintf("%s/%s/%s", namePrefix, province, name)
  272. fullIndexNamePingyin = namePrefixPingin + provincePingyin + namePingin
  273. }
  274. if name == "90kg以下" || name == "150kg以上" {
  275. unit = "%"
  276. }
  277. indexItem, okIndex := indexMap[fullIndexName]
  278. if !okIndex {
  279. // 新增指标
  280. indexItem = new(models.YongyiExcelIndex)
  281. indexItem.IndexName = fullIndexName
  282. indexItem.ClassifyName = classifyName
  283. indexItem.ClassifySort = classifySort
  284. indexItem.IndexCode = fullIndexNamePingyin
  285. indexItem.Frequency = frequency
  286. indexItem.Sort = sort
  287. indexItem.Unit = unit
  288. indexItem.ExcelDataMap = make(map[string]string)
  289. sort++
  290. }
  291. fmt.Printf("indexItem%s", indexItem.IndexCode)
  292. indexItem.ExcelDataMap[date] = text
  293. indexMap[fullIndexName] = indexItem
  294. continue
  295. }
  296. }
  297. }
  298. for _, v := range indexMap {
  299. indexList = append(indexList, v)
  300. }
  301. return
  302. }
  303. // HandleYongyiExcelWeekly3 周度-屠宰厂宰前活猪重
  304. func HandleYongyiExcelWeekly3(sheet *xlsx.Sheet) (indexList []*models.YongyiExcelIndex, err error) {
  305. classifyName := "周度-屠宰厂宰前活猪重"
  306. classifyMap := getClassifySortMap()
  307. classifySort, _ := classifyMap[classifyName]
  308. frequency := "周度"
  309. unit := "公斤"
  310. namePrefix := "商品猪宰前活猪重"
  311. namePrefixPingin := "yyzx" + utils.GetFirstPingYin(namePrefix)
  312. // 遍历行读取
  313. indexList = make([]*models.YongyiExcelIndex, 0)
  314. provinceMap := make(map[int]string)
  315. maxRow := sheet.MaxRow
  316. sort := 0
  317. fmt.Println("最大行")
  318. fmt.Println(maxRow)
  319. // 指标名称
  320. indexMap := make(map[string]*models.YongyiExcelIndex)
  321. for i := 0; i < maxRow; i++ {
  322. fmt.Printf("当前第%d行 \n", i)
  323. if i < 2 {
  324. continue
  325. }
  326. if i == 2 { // 首行,表示时间
  327. row := sheet.Row(i)
  328. cells := row.Cells
  329. for k, cell := range cells {
  330. text := cell.String()
  331. if k > 2 && text != "" {
  332. // 检查单元格是否为合并单元格
  333. if cell.VMerge > 0 {
  334. provinceMap[k] = text
  335. }
  336. }
  337. }
  338. } else if i == 3 { //表示表头
  339. // 处理 index指标表
  340. row := sheet.Row(i)
  341. cells := row.Cells
  342. for k, cell := range cells {
  343. text := cell.String()
  344. if text != "" {
  345. provinceMap[k] = text
  346. }
  347. }
  348. } else { //数据列
  349. row := sheet.Row(i)
  350. cells := row.Cells
  351. date := ""
  352. for k, cell := range cells {
  353. fmt.Printf("当前第%d列 \n", k)
  354. text := cell.String()
  355. if k == 0 {
  356. continue
  357. } else if k == 1 {
  358. tmpRow := row
  359. r := &ExcelDateRecord{}
  360. if e := tmpRow.ReadStruct(r); e != nil {
  361. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 读取行,时间列失败 Err:%s", sheet.Name, i, k, e))
  362. continue
  363. }
  364. date = r.Date.Format(utils.FormatDate)
  365. fmt.Println(date)
  366. continue
  367. } else if k == 2 {
  368. continue
  369. } else {
  370. // 判断出不是字符的,则过滤
  371. if text == "" {
  372. continue
  373. }
  374. if strings.Contains(text, "%") {
  375. text = strings.Replace(text, "%", "", 1)
  376. }
  377. _, e := strconv.ParseFloat(text, 64)
  378. if e != nil {
  379. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 strconv.ParseFloat Err:%s", sheet.Name, i, k, e))
  380. continue
  381. }
  382. }
  383. province, ok2 := provinceMap[k]
  384. if !ok2 {
  385. err = fmt.Errorf("找不到对应的列名,第%d行,第%d列", i, k)
  386. return
  387. }
  388. if province == "较上周" {
  389. continue
  390. } else if province == "全国平均" {
  391. province = "全国"
  392. }
  393. fmt.Printf("当前第%d行第%d列, 当前省份%s \n", i, k, province)
  394. // 处理指标名称
  395. fullIndexName := fmt.Sprintf("%s/%s", namePrefix, province)
  396. provincePingyin := utils.GetFullPingYin(province)
  397. fullIndexNamePingyin := namePrefixPingin + provincePingyin
  398. indexItem, okIndex := indexMap[fullIndexName]
  399. if !okIndex {
  400. // 新增指标
  401. indexItem = new(models.YongyiExcelIndex)
  402. indexItem.IndexName = fullIndexName
  403. indexItem.ClassifyName = classifyName
  404. indexItem.ClassifySort = classifySort
  405. indexItem.IndexCode = fullIndexNamePingyin
  406. indexItem.Frequency = frequency
  407. indexItem.Sort = sort
  408. indexItem.Unit = unit
  409. indexItem.ExcelDataMap = make(map[string]string)
  410. sort++
  411. }
  412. fmt.Printf("indexItem%s", indexItem.IndexCode)
  413. indexItem.ExcelDataMap[date] = text
  414. indexMap[fullIndexName] = indexItem
  415. continue
  416. }
  417. }
  418. }
  419. for _, v := range indexMap {
  420. indexList = append(indexList, v)
  421. }
  422. return
  423. }
  424. // HandleYongyiExcelWeekly4 周度-各体重段价差
  425. func HandleYongyiExcelWeekly4(sheet *xlsx.Sheet) (indexList []*models.YongyiExcelIndex, err error) {
  426. classifyName := "周度-各体重段价差"
  427. classifyMap := getClassifySortMap()
  428. classifySort, _ := classifyMap[classifyName]
  429. frequency := "周度"
  430. unit := "元/斤"
  431. namePrefixPingin := "yyzx"
  432. // 遍历行读取
  433. indexList = make([]*models.YongyiExcelIndex, 0)
  434. provinceMap := make(map[int]string)
  435. maxRow := sheet.MaxRow
  436. sort := 0
  437. fmt.Println("最大行")
  438. fmt.Println(maxRow)
  439. // 指标名称
  440. indexMap := make(map[string]*models.YongyiExcelIndex)
  441. for i := 0; i < maxRow; i++ {
  442. fmt.Printf("当前第%d行 \n", i)
  443. if i == 0 {
  444. continue
  445. } else if i == 1 { //表示表头
  446. // 处理 index指标表
  447. row := sheet.Row(i)
  448. cells := row.Cells
  449. for k, cell := range cells {
  450. text := cell.String()
  451. if text != "" {
  452. provinceMap[k] = text
  453. }
  454. }
  455. } else { //数据列
  456. row := sheet.Row(i)
  457. cells := row.Cells
  458. date := ""
  459. name := ""
  460. for k, cell := range cells {
  461. fmt.Printf("当前第%d列 \n", k)
  462. text := cell.String()
  463. if k == 0 {
  464. continue
  465. } else if k == 1 {
  466. tmpRow := row
  467. r := &ExcelDateRecord{}
  468. if e := tmpRow.ReadStruct(r); e != nil {
  469. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 读取行,时间列失败 Err:%s", sheet.Name, i, k, e))
  470. continue
  471. }
  472. date = r.Date.Format(utils.FormatDate)
  473. fmt.Println(date)
  474. continue
  475. } else if k == 2 {
  476. name = text
  477. if name == "标猪" {
  478. name += "价格"
  479. } else {
  480. name += "猪价格"
  481. }
  482. continue
  483. } else {
  484. // 判断出不是字符的,则过滤
  485. if text == "" {
  486. continue
  487. }
  488. if strings.Contains(text, "%") {
  489. text = strings.Replace(text, "%", "", 1)
  490. }
  491. _, e := strconv.ParseFloat(text, 64)
  492. if e != nil {
  493. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 strconv.ParseFloat Err:%s", sheet.Name, i, k, e))
  494. continue
  495. }
  496. }
  497. province, ok2 := provinceMap[k]
  498. if !ok2 {
  499. err = fmt.Errorf("找不到对应的列名,第%d行,第%d列", i, k)
  500. return
  501. }
  502. if name != "标猪价格" && name != "150kg猪价格" && name != "175kg猪价格" && name != "200kg猪价格" {
  503. continue
  504. }
  505. fmt.Printf("当前第%d行第%d列, 当前省份%s \n", i, k, province)
  506. // 处理指标名称
  507. fullIndexName := fmt.Sprintf("%s/%s", name, province)
  508. provincePingyin := utils.GetFullPingYin(province)
  509. namePingin := utils.GetFirstPingYin(name)
  510. fullIndexNamePingyin := namePrefixPingin + namePingin + provincePingyin
  511. indexItem, okIndex := indexMap[fullIndexName]
  512. if !okIndex {
  513. // 新增指标
  514. indexItem = new(models.YongyiExcelIndex)
  515. indexItem.IndexName = fullIndexName
  516. indexItem.ClassifyName = classifyName
  517. indexItem.ClassifySort = classifySort
  518. indexItem.IndexCode = fullIndexNamePingyin
  519. indexItem.Frequency = frequency
  520. indexItem.Sort = sort
  521. indexItem.Unit = unit
  522. indexItem.ExcelDataMap = make(map[string]string)
  523. sort++
  524. }
  525. fmt.Printf("IndexCode: %s", indexItem.IndexCode)
  526. indexItem.ExcelDataMap[date] = text
  527. indexMap[fullIndexName] = indexItem
  528. continue
  529. }
  530. }
  531. }
  532. for _, v := range indexMap {
  533. indexList = append(indexList, v)
  534. }
  535. return
  536. }
  537. // HandleYongyiExcelWeekly5 周度-50公斤二元母猪价格
  538. func HandleYongyiExcelWeekly5(sheet *xlsx.Sheet) (indexList []*models.YongyiExcelIndex, err error) {
  539. info, ok := YongyiWeeklySheetMap5[sheet.Name]
  540. if !ok {
  541. return
  542. }
  543. classifyName := info.ClassifyName
  544. classifyMap := getClassifySortMap()
  545. classifySort, _ := classifyMap[classifyName]
  546. frequency := info.Frequency
  547. unit := info.Unit
  548. namePrefix := info.NamePrefix
  549. namePrefixPingin := "yyzx" + utils.GetFirstPingYin(namePrefix)
  550. /*classifyName := "周度-50公斤二元母猪价格"
  551. frequency := "周度"
  552. unit := "元/头"
  553. namePrefix := "50公斤二元母猪价格"
  554. namePrefixPingin := "yyzx50gjeymzjg"*/
  555. /* classifyName := "周度-规模场15公斤仔猪出栏价"
  556. frequency := "周度"
  557. unit := "元/头"
  558. namePrefix := "规模场15公斤仔猪出栏价"
  559. namePrefixPingin := "yyzxgmc15gjzzclj"*/
  560. // 遍历行读取
  561. indexList = make([]*models.YongyiExcelIndex, 0)
  562. provinceMap := make(map[int]string)
  563. maxRow := sheet.MaxRow
  564. sort := 0
  565. fmt.Println("最大行")
  566. fmt.Println(maxRow)
  567. // 指标名称
  568. indexMap := make(map[string]*models.YongyiExcelIndex)
  569. for i := 0; i < maxRow; i++ {
  570. fmt.Printf("当前第%d行 \n", i)
  571. if i == 0 {
  572. row := sheet.Row(i)
  573. cells := row.Cells
  574. for k, cell := range cells {
  575. text := cell.String()
  576. if k > 1 && text != "" {
  577. if cell.VMerge > 0 {
  578. provinceMap[k] = text
  579. }
  580. }
  581. }
  582. continue
  583. } else if i == 1 { //表示表头
  584. // 处理 index指标表
  585. row := sheet.Row(i)
  586. cells := row.Cells
  587. for k, cell := range cells {
  588. text := cell.String()
  589. if text != "" {
  590. provinceMap[k] = text
  591. }
  592. }
  593. } else { //数据列
  594. row := sheet.Row(i)
  595. cells := row.Cells
  596. date := ""
  597. for k, cell := range cells {
  598. fmt.Printf("当前第%d列 \n", k)
  599. text := cell.String()
  600. if k == 0 {
  601. continue
  602. } else if k == 1 {
  603. tmpRow := row
  604. r := &ExcelDateRecord{}
  605. if e := tmpRow.ReadStruct(r); e != nil {
  606. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 读取行,时间列失败 Err:%s", sheet.Name, i, k, e))
  607. continue
  608. }
  609. date = r.Date.Format(utils.FormatDate)
  610. fmt.Println(date)
  611. continue
  612. } else {
  613. // 判断出不是字符的,则过滤
  614. if text == "" {
  615. continue
  616. }
  617. if strings.Contains(text, "%") {
  618. text = strings.Replace(text, "%", "", 1)
  619. }
  620. _, e := strconv.ParseFloat(text, 64)
  621. if e != nil {
  622. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 strconv.ParseFloat Err:%s", sheet.Name, i, k, e))
  623. continue
  624. }
  625. }
  626. province, ok2 := provinceMap[k]
  627. if !ok2 {
  628. err = fmt.Errorf("找不到对应的列名,第%d行,第%d列", i, k)
  629. return
  630. }
  631. if province == "全 国1" || province == "全 国2" || province == "全国1" || province == "全国2" {
  632. province = strings.ReplaceAll(province, " ", "")
  633. }
  634. fmt.Printf("当前第%d行第%d列, 当前省份%s \n", i, k, province)
  635. // 处理指标名称
  636. fullIndexName := fmt.Sprintf("%s/%s", namePrefix, province)
  637. provincePingyin := utils.GetFullPingYin(province)
  638. fullIndexNamePingyin := namePrefixPingin + provincePingyin
  639. indexItem, okIndex := indexMap[fullIndexName]
  640. if !okIndex {
  641. // 新增指标
  642. indexItem = new(models.YongyiExcelIndex)
  643. indexItem.IndexName = fullIndexName
  644. indexItem.ClassifyName = classifyName
  645. indexItem.ClassifySort = classifySort
  646. indexItem.IndexCode = fullIndexNamePingyin
  647. indexItem.Frequency = frequency
  648. indexItem.Sort = sort
  649. indexItem.Unit = unit
  650. indexItem.ExcelDataMap = make(map[string]string)
  651. sort++
  652. }
  653. fmt.Printf("IndexCode: %s", indexItem.IndexCode)
  654. indexItem.ExcelDataMap[date] = text
  655. indexMap[fullIndexName] = indexItem
  656. continue
  657. }
  658. }
  659. }
  660. for _, v := range indexMap {
  661. indexList = append(indexList, v)
  662. }
  663. return
  664. }
  665. // HandleYongyiExcelWeekly6 周度-冻品库存多样本
  666. func HandleYongyiExcelWeekly6(sheet *xlsx.Sheet) (indexList []*models.YongyiExcelIndex, err error) {
  667. info, ok := YongyiWeeklySheetMap6[sheet.Name]
  668. if !ok {
  669. return
  670. }
  671. classifyName := info.ClassifyName
  672. classifyMap := getClassifySortMap()
  673. classifySort, _ := classifyMap[classifyName]
  674. frequency := info.Frequency
  675. unit := info.Unit
  676. namePrefix := info.NamePrefix
  677. namePrefixPingin := "yyzx" + utils.GetFirstPingYin(namePrefix)
  678. /*classifyName := "周度-冻品库存多样本"
  679. frequency := "周度"
  680. unit := "%"
  681. namePrefix := "冻品库存多样本"
  682. namePrefixPingin := "yyzxdpkcdyb"*/
  683. // 遍历行读取
  684. indexList = make([]*models.YongyiExcelIndex, 0)
  685. areaMap := make(map[int]string)
  686. maxRow := sheet.MaxRow
  687. sort := 0
  688. fmt.Println("最大行")
  689. fmt.Println(maxRow)
  690. // 指标名称
  691. indexMap := make(map[string]*models.YongyiExcelIndex)
  692. for i := 0; i < maxRow; i++ {
  693. fmt.Printf("当前第%d行 \n", i)
  694. if i == 0 {
  695. continue
  696. } else if i == 1 { //表示表头
  697. // 处理 index指标表
  698. row := sheet.Row(i)
  699. cells := row.Cells
  700. for k, cell := range cells {
  701. text := cell.String()
  702. if text != "" {
  703. areaMap[k] = text
  704. }
  705. }
  706. } else { //数据列
  707. row := sheet.Row(i)
  708. cells := row.Cells
  709. date := ""
  710. for k, cell := range cells {
  711. fmt.Printf("当前第%d列 \n", k)
  712. text := cell.String()
  713. if k == 0 {
  714. tmpRow := row
  715. r := &ExcelDateRecordFirst{}
  716. if e := tmpRow.ReadStruct(r); e != nil {
  717. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 读取行,时间列失败 Err:%s", sheet.Name, i, k, e))
  718. continue
  719. }
  720. date = r.Date.Format(utils.FormatDate)
  721. fmt.Println(date)
  722. continue
  723. } else {
  724. // 判断出不是字符的,则过滤
  725. if text == "" {
  726. continue
  727. }
  728. if strings.Contains(text, "%") {
  729. text = strings.Replace(text, "%", "", 1)
  730. }
  731. _, e := strconv.ParseFloat(text, 64)
  732. if e != nil {
  733. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 strconv.ParseFloat Err:%s", sheet.Name, i, k, e))
  734. continue
  735. }
  736. }
  737. area, ok2 := areaMap[k]
  738. if !ok2 {
  739. err = fmt.Errorf("找不到对应的列名,第%d行,第%d列", i, k)
  740. return
  741. }
  742. fmt.Printf("当前第%d行第%d列, 当前省份%s \n", i, k, area)
  743. // 处理指标名称
  744. fullIndexName := fmt.Sprintf("%s/%s", namePrefix, area)
  745. areaPingyin := utils.GetFirstPingYin(area)
  746. if sheet.Name == "月度出栏完成率" {
  747. areaPingyin = utils.GetFullPingYin(area)
  748. }
  749. fullIndexNamePingyin := namePrefixPingin + areaPingyin
  750. indexItem, okIndex := indexMap[fullIndexName]
  751. if !okIndex {
  752. // 新增指标
  753. indexItem = new(models.YongyiExcelIndex)
  754. indexItem.IndexName = fullIndexName
  755. indexItem.ClassifyName = classifyName
  756. indexItem.ClassifySort = classifySort
  757. indexItem.IndexCode = fullIndexNamePingyin
  758. indexItem.Frequency = frequency
  759. indexItem.Sort = sort
  760. indexItem.Unit = unit
  761. indexItem.ExcelDataMap = make(map[string]string)
  762. sort++
  763. }
  764. fmt.Printf("IndexCode: %s", indexItem.IndexCode)
  765. indexItem.ExcelDataMap[date] = text
  766. indexMap[fullIndexName] = indexItem
  767. continue
  768. }
  769. }
  770. }
  771. for _, v := range indexMap {
  772. indexList = append(indexList, v)
  773. }
  774. return
  775. }
  776. // HandleYongyiExcelWeekly7 月度计划出栏量
  777. func HandleYongyiExcelWeekly7(sheet *xlsx.Sheet) (indexList []*models.YongyiExcelIndex, err error) {
  778. classifyName := "月度计划出栏量"
  779. classifyMap := getClassifySortMap()
  780. classifySort, _ := classifyMap[classifyName]
  781. frequency := "月度"
  782. unit := "%"
  783. namePrefix := "月度计划出栏量环比"
  784. namePrefixPingin := "yyzx" + utils.GetFirstPingYin(namePrefix)
  785. // 遍历行读取
  786. indexList = make([]*models.YongyiExcelIndex, 0)
  787. provinceMap := make(map[int]string)
  788. firstMap := make(map[int]string)
  789. maxRow := sheet.MaxRow
  790. sort := 0
  791. fmt.Println("最大行")
  792. fmt.Println(maxRow)
  793. // 指标名称
  794. indexMap := make(map[string]*models.YongyiExcelIndex)
  795. for i := 0; i < maxRow; i++ {
  796. fmt.Printf("当前第%d行 \n", i)
  797. if i == 0 {
  798. // 处理 index指标表
  799. row := sheet.Row(i)
  800. cells := row.Cells
  801. for k, cell := range cells {
  802. text := cell.String()
  803. if text != "" {
  804. firstMap[k] = text
  805. }
  806. }
  807. continue
  808. } else if i == 1 { //表示表头
  809. // 处理 index指标表
  810. row := sheet.Row(i)
  811. cells := row.Cells
  812. for k, cell := range cells {
  813. text := cell.String()
  814. if text != "" {
  815. provinceMap[k] = text
  816. }
  817. }
  818. } else { //数据列
  819. row := sheet.Row(i)
  820. cells := row.Cells
  821. date := ""
  822. for k, cell := range cells {
  823. fmt.Printf("当前第%d列 \n", k)
  824. text := cell.String()
  825. if k == 0 {
  826. tmpRow := row
  827. r := &ExcelDateRecordFirst{}
  828. if e := tmpRow.ReadStruct(r); e != nil {
  829. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 读取行,时间列失败 Err:%s", sheet.Name, i, k, e))
  830. continue
  831. }
  832. // 查询当月的最后一天
  833. monthDate := r.Date.Format(utils.FormatYearMonthDate)
  834. firstDayStr := monthDate + "-01"
  835. tmpT, _ := time.ParseInLocation(utils.FormatDate, firstDayStr, time.Local)
  836. date = tmpT.AddDate(0, 1, -1).Format(utils.FormatDate)
  837. fmt.Println(date)
  838. continue
  839. } else {
  840. // 判断出不是字符的,则过滤
  841. if text == "" {
  842. continue
  843. }
  844. if strings.Contains(text, "%") {
  845. text = strings.Replace(text, "%", "", 1)
  846. }
  847. _, e := strconv.ParseFloat(text, 64)
  848. if e != nil {
  849. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 strconv.ParseFloat Err:%s", sheet.Name, i, k, e))
  850. continue
  851. }
  852. }
  853. province, ok1 := provinceMap[k]
  854. if !ok1 {
  855. err = fmt.Errorf("找不到对应的列名,第%d行,第%d列", i, k)
  856. return
  857. }
  858. if province == "本月计划较上月实际销售" {
  859. continue
  860. }
  861. fmt.Printf("当前第%d行第%d列, 当前省份: %s \n", i, k, province)
  862. // 处理指标名称
  863. fullIndexName := fmt.Sprintf("%s/%s", namePrefix, province)
  864. provincePingyin := utils.GetFullPingYin(province)
  865. fullIndexNamePingyin := namePrefixPingin + provincePingyin
  866. if province == "数量" {
  867. first, ok2 := firstMap[k]
  868. if !ok2 {
  869. continue
  870. }
  871. fullIndexName = first
  872. firstPingyin := utils.GetFirstPingYin(first)
  873. fullIndexNamePingyin = "yyzx" + firstPingyin
  874. unit = "万头"
  875. }
  876. indexItem, okIndex := indexMap[fullIndexName]
  877. if !okIndex {
  878. // 新增指标
  879. indexItem = new(models.YongyiExcelIndex)
  880. indexItem.IndexName = fullIndexName
  881. indexItem.ClassifyName = classifyName
  882. indexItem.ClassifySort = classifySort
  883. indexItem.IndexCode = fullIndexNamePingyin
  884. indexItem.Frequency = frequency
  885. indexItem.Sort = sort
  886. indexItem.Unit = unit
  887. indexItem.ExcelDataMap = make(map[string]string)
  888. sort++
  889. }
  890. fmt.Printf("IndexCode: %s\n", indexItem.IndexCode)
  891. indexItem.ExcelDataMap[date] = text
  892. indexMap[fullIndexName] = indexItem
  893. continue
  894. }
  895. }
  896. }
  897. for _, v := range indexMap {
  898. indexList = append(indexList, v)
  899. }
  900. return
  901. }
  902. // HandleYongyiExcelWeekly8 月度-能繁母猪存栏(2020年2月新增)
  903. func HandleYongyiExcelWeekly8(sheet *xlsx.Sheet) (indexList []*models.YongyiExcelIndex, err error) {
  904. classifyName := "月度-能繁母猪存栏(2020年2月新增)"
  905. classifyMap := getClassifySortMap()
  906. classifySort, _ := classifyMap[classifyName]
  907. frequency := "月度"
  908. unit := "头"
  909. namePrefix := "能繁母猪存栏量"
  910. namePrefixPingin := "yyzx" + utils.GetFirstPingYin(namePrefix)
  911. // 遍历行读取
  912. indexList = make([]*models.YongyiExcelIndex, 0)
  913. areaMap := make(map[int]string)
  914. maxRow := sheet.MaxRow
  915. sort := 0
  916. fmt.Println("最大行")
  917. fmt.Println(maxRow)
  918. // 指标名称
  919. indexMap := make(map[string]*models.YongyiExcelIndex)
  920. for i := 0; i < maxRow; i++ {
  921. fmt.Printf("当前第%d行 \n", i)
  922. if i <= 2 {
  923. continue
  924. } else if i == 3 { //表示表头
  925. // 处理 index指标表
  926. row := sheet.Row(i)
  927. cells := row.Cells
  928. for k, cell := range cells {
  929. text := cell.String()
  930. if text != "" {
  931. areaMap[k] = text
  932. }
  933. }
  934. } else { //数据列
  935. row := sheet.Row(i)
  936. cells := row.Cells
  937. date := ""
  938. for k, cell := range cells {
  939. fmt.Printf("当前第%d列 \n", k)
  940. text := cell.String()
  941. if k == 0 {
  942. tmpRow := row
  943. r := &ExcelDateRecordFirst{}
  944. if e := tmpRow.ReadStruct(r); e != nil {
  945. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 读取行,时间列失败 Err:%s", sheet.Name, i, k, e))
  946. continue
  947. }
  948. // 查询当月的最后一天
  949. monthDate := r.Date.Format(utils.FormatYearMonthDate)
  950. firstDayStr := monthDate + "-01"
  951. tmpT, _ := time.ParseInLocation(utils.FormatDate, firstDayStr, time.Local)
  952. date = tmpT.AddDate(0, 1, -1).Format(utils.FormatDate)
  953. fmt.Println(date)
  954. continue
  955. } else {
  956. // 判断出不是字符的,则过滤
  957. if text == "" {
  958. continue
  959. }
  960. if strings.Contains(text, "%") {
  961. text = strings.Replace(text, "%", "", 1)
  962. }
  963. _, e := strconv.ParseFloat(text, 64)
  964. if e != nil {
  965. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 strconv.ParseFloat Err:%s", sheet.Name, i, k, e))
  966. continue
  967. }
  968. }
  969. area, ok1 := areaMap[k]
  970. if !ok1 {
  971. err = fmt.Errorf("找不到对应的列名,第%d行,第%d列", i, k)
  972. return
  973. }
  974. if area == "环比" || area == "日期" || area == "同比" {
  975. continue
  976. }
  977. fmt.Printf("当前第%d行第%d列, 当前省份: %s \n", i, k, area)
  978. // 处理指标名称
  979. fullIndexName := fmt.Sprintf("%s/%s", namePrefix, area)
  980. areaPingyin := utils.GetFirstPingYin(area)
  981. fullIndexNamePingyin := namePrefixPingin + areaPingyin
  982. indexItem, okIndex := indexMap[fullIndexName]
  983. if !okIndex {
  984. // 新增指标
  985. indexItem = new(models.YongyiExcelIndex)
  986. indexItem.IndexName = fullIndexName
  987. indexItem.ClassifyName = classifyName
  988. indexItem.ClassifySort = classifySort
  989. indexItem.IndexCode = fullIndexNamePingyin
  990. indexItem.Frequency = frequency
  991. indexItem.Sort = sort
  992. indexItem.Unit = unit
  993. indexItem.ExcelDataMap = make(map[string]string)
  994. sort++
  995. }
  996. fmt.Printf("IndexCode: %s\n", indexItem.IndexCode)
  997. indexItem.ExcelDataMap[date] = text
  998. indexMap[fullIndexName] = indexItem
  999. continue
  1000. }
  1001. }
  1002. }
  1003. for _, v := range indexMap {
  1004. indexList = append(indexList, v)
  1005. }
  1006. return
  1007. }
  1008. // HandleYongyiExcelWeekly9 月度-小猪存栏(2020年5月新增)
  1009. func HandleYongyiExcelWeekly9(sheet *xlsx.Sheet) (indexList []*models.YongyiExcelIndex, err error) {
  1010. info, ok := YongyiWeeklySheetMap9[sheet.Name]
  1011. if !ok {
  1012. return
  1013. }
  1014. classifyName := info.ClassifyName
  1015. classifyMap := getClassifySortMap()
  1016. classifySort, _ := classifyMap[classifyName]
  1017. frequency := info.Frequency
  1018. unit := info.Unit
  1019. namePrefix := info.NamePrefix
  1020. namePrefixPingin := "yyzx" + utils.GetFirstPingYin(namePrefix)
  1021. // 遍历行读取
  1022. indexList = make([]*models.YongyiExcelIndex, 0)
  1023. areaMap := make(map[int]string)
  1024. maxRow := sheet.MaxRow
  1025. sort := 0
  1026. fmt.Println("最大行")
  1027. fmt.Println(maxRow)
  1028. // 指标名称
  1029. indexMap := make(map[string]*models.YongyiExcelIndex)
  1030. for i := 0; i < maxRow; i++ {
  1031. fmt.Printf("当前第%d行 \n", i)
  1032. if i <= 1 {
  1033. continue
  1034. } else if i == 2 { //表示表头
  1035. // 处理 index指标表
  1036. row := sheet.Row(i)
  1037. cells := row.Cells
  1038. for k, cell := range cells {
  1039. text := cell.String()
  1040. if text != "" {
  1041. areaMap[k] = text
  1042. }
  1043. }
  1044. } else { //数据列
  1045. row := sheet.Row(i)
  1046. cells := row.Cells
  1047. date := ""
  1048. for k, cell := range cells {
  1049. fmt.Printf("当前第%d列 \n", k)
  1050. text := cell.String()
  1051. if k == 0 {
  1052. tmpRow := row
  1053. r := &ExcelDateRecordFirst{}
  1054. if e := tmpRow.ReadStruct(r); e != nil {
  1055. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 读取行,时间列失败 Err:%s", sheet.Name, i, k, e))
  1056. continue
  1057. }
  1058. // 查询当月的最后一天
  1059. monthDate := r.Date.Format(utils.FormatYearMonthDate)
  1060. firstDayStr := monthDate + "-01"
  1061. tmpT, _ := time.ParseInLocation(utils.FormatDate, firstDayStr, time.Local)
  1062. date = tmpT.AddDate(0, 1, -1).Format(utils.FormatDate)
  1063. fmt.Println(date)
  1064. continue
  1065. } else {
  1066. // 判断出不是字符的,则过滤
  1067. if text == "" {
  1068. continue
  1069. }
  1070. if strings.Contains(text, "%") {
  1071. text = strings.Replace(text, "%", "", 1)
  1072. }
  1073. _, e := strconv.ParseFloat(text, 64)
  1074. if e != nil {
  1075. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 strconv.ParseFloat Err:%s", sheet.Name, i, k, e))
  1076. continue
  1077. }
  1078. }
  1079. area, ok1 := areaMap[k]
  1080. if !ok1 {
  1081. err = fmt.Errorf("找不到对应的列名,第%d行,第%d列", i, k)
  1082. return
  1083. }
  1084. if area == "环比" || area == "日期" || area == "同比" {
  1085. continue
  1086. }
  1087. fmt.Printf("当前第%d行第%d列, 当前省份: %s \n", i, k, area)
  1088. // 处理指标名称
  1089. fullIndexName := fmt.Sprintf("%s/%s", namePrefix, area)
  1090. areaPingyin := utils.GetFirstPingYin(area)
  1091. fullIndexNamePingyin := namePrefixPingin + areaPingyin
  1092. indexItem, okIndex := indexMap[fullIndexName]
  1093. if !okIndex {
  1094. // 新增指标
  1095. indexItem = new(models.YongyiExcelIndex)
  1096. indexItem.IndexName = fullIndexName
  1097. indexItem.ClassifyName = classifyName
  1098. indexItem.ClassifySort = classifySort
  1099. indexItem.IndexCode = fullIndexNamePingyin
  1100. indexItem.Frequency = frequency
  1101. indexItem.Sort = sort
  1102. indexItem.Unit = unit
  1103. indexItem.ExcelDataMap = make(map[string]string)
  1104. sort++
  1105. }
  1106. fmt.Printf("IndexCode: %s\n", indexItem.IndexCode)
  1107. indexItem.ExcelDataMap[date] = text
  1108. indexMap[fullIndexName] = indexItem
  1109. continue
  1110. }
  1111. }
  1112. }
  1113. for _, v := range indexMap {
  1114. indexList = append(indexList, v)
  1115. }
  1116. return
  1117. }
  1118. // HandleYongyiExcelWeekly10 月度-商品猪出栏量
  1119. func HandleYongyiExcelWeekly10(sheet *xlsx.Sheet) (indexList []*models.YongyiExcelIndex, err error) {
  1120. classifyName := "月度-商品猪出栏量"
  1121. classifyMap := getClassifySortMap()
  1122. classifySort, _ := classifyMap[classifyName]
  1123. frequency := "月度"
  1124. unit := "头"
  1125. namePrefix := "商品猪出栏量"
  1126. namePrefixPingin := "yyzx" + utils.GetFirstPingYin(namePrefix)
  1127. // 遍历行读取
  1128. indexList = make([]*models.YongyiExcelIndex, 0)
  1129. areaMap := make(map[int]string)
  1130. maxRow := sheet.MaxRow
  1131. sort := 0
  1132. fmt.Println("最大行")
  1133. fmt.Println(maxRow)
  1134. // 指标名称
  1135. indexMap := make(map[string]*models.YongyiExcelIndex)
  1136. for i := 0; i < maxRow; i++ {
  1137. fmt.Printf("当前第%d行 \n", i)
  1138. if i == 0 {
  1139. continue
  1140. } else if i == 1 { //表示表头
  1141. // 处理 index指标表
  1142. row := sheet.Row(i)
  1143. cells := row.Cells
  1144. for k, cell := range cells {
  1145. text := cell.String()
  1146. if text != "" {
  1147. areaMap[k] = text
  1148. }
  1149. }
  1150. } else { //数据列
  1151. row := sheet.Row(i)
  1152. cells := row.Cells
  1153. date := ""
  1154. for k, cell := range cells {
  1155. fmt.Printf("当前第%d列 \n", k)
  1156. text := cell.String()
  1157. if k == 0 {
  1158. tmpRow := row
  1159. r := &ExcelDateRecordFirst{}
  1160. if e := tmpRow.ReadStruct(r); e != nil {
  1161. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 读取行,时间列失败 Err:%s", sheet.Name, i, k, e))
  1162. continue
  1163. }
  1164. // 查询当月的最后一天
  1165. monthDate := r.Date.Format(utils.FormatYearMonthDate)
  1166. firstDayStr := monthDate + "-01"
  1167. tmpT, _ := time.ParseInLocation(utils.FormatDate, firstDayStr, time.Local)
  1168. date = tmpT.AddDate(0, 1, -1).Format(utils.FormatDate)
  1169. fmt.Println(date)
  1170. continue
  1171. } else {
  1172. // 判断出不是字符的,则过滤
  1173. if text == "" {
  1174. continue
  1175. }
  1176. if strings.Contains(text, "%") {
  1177. text = strings.Replace(text, "%", "", 1)
  1178. }
  1179. _, e := strconv.ParseFloat(text, 64)
  1180. if e != nil {
  1181. utils.FileLog.Info(fmt.Sprintf("sheet:%s 第%d行, 第%d列 strconv.ParseFloat Err:%s", sheet.Name, i, k, e))
  1182. continue
  1183. }
  1184. }
  1185. area, ok1 := areaMap[k]
  1186. if !ok1 {
  1187. err = fmt.Errorf("找不到对应的列名,第%d行,第%d列", i, k)
  1188. return
  1189. }
  1190. if area == "环比" || area == "日期" || area == "同比" || area == "较非瘟前" {
  1191. continue
  1192. }
  1193. fmt.Printf("当前第%d行第%d列, 当前省份: %s \n", i, k, area)
  1194. // 处理指标名称
  1195. fullIndexName := fmt.Sprintf("%s/%s", namePrefix, area)
  1196. areaPingyin := utils.GetFirstPingYin(area)
  1197. fullIndexNamePingyin := namePrefixPingin + areaPingyin
  1198. indexItem, okIndex := indexMap[fullIndexName]
  1199. if !okIndex {
  1200. // 新增指标
  1201. indexItem = new(models.YongyiExcelIndex)
  1202. indexItem.IndexName = fullIndexName
  1203. indexItem.ClassifyName = classifyName
  1204. indexItem.ClassifySort = classifySort
  1205. indexItem.IndexCode = fullIndexNamePingyin
  1206. indexItem.Frequency = frequency
  1207. indexItem.Sort = sort
  1208. indexItem.Unit = unit
  1209. indexItem.ExcelDataMap = make(map[string]string)
  1210. sort++
  1211. }
  1212. fmt.Printf("IndexCode: %s\n", indexItem.IndexCode)
  1213. indexItem.ExcelDataMap[date] = text
  1214. indexMap[fullIndexName] = indexItem
  1215. continue
  1216. }
  1217. }
  1218. }
  1219. for _, v := range indexMap {
  1220. indexList = append(indexList, v)
  1221. }
  1222. return
  1223. }