wareInfo.go 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. /**
  2. * @Author : zou.yingbin
  3. * @Create : 2022/3/23 11:05
  4. * @Modify : 2022/3/23 11:05
  5. * @note :
  6. */
  7. package client
  8. type wareInfo struct {
  9. buf []byte // 内容[报价开始(0x10):报价结束(0x11)]
  10. exchId string // 交易所id
  11. goodsCode string // 商品代码
  12. ask string // 卖价
  13. bid string // 买价
  14. last string // 最新价
  15. tm string // 时间
  16. }
  17. func (r *wareInfo) getField(tag byte) string {
  18. for i, v := range r.buf {
  19. if v == tag {
  20. if i > 0 && r.buf[i-1] == 0x01 {
  21. for j, d := range r.buf[i:] {
  22. if d == 0x01 || d == 0x11 {
  23. buf := r.buf[i+2 : i+j]
  24. return string(buf)
  25. }
  26. }
  27. }
  28. }
  29. }
  30. return ""
  31. }
  32. func (r *wareInfo) parseField() {
  33. r.goodsCode = r.getField(0x21)
  34. r.ask = r.getField(0x4c)
  35. r.bid = r.getField(0x42)
  36. r.last = r.getField(0x24)
  37. r.tm = r.getField(0x41)
  38. r.exchId = r.getField(0x56)
  39. if r.exchId == "200" {
  40. r.goodsCode = "200"
  41. }
  42. }
  43. // func (r *wareInfo) printInfo() {
  44. // if r.ask == "" {
  45. // return
  46. // }
  47. // log.Println(r.exchId, r.goodsCode, r.ask, r.bid, r.last, r.tm)
  48. // }
  49. // func (r *wareInfo) debugPrintAllField() {
  50. // if len(r.buf) <= 2 {
  51. // return
  52. // }
  53. // if r.buf[0] != 0x10 || r.buf[len(r.buf)-1] != 0x11 {
  54. // return
  55. // }
  56. // type Field struct {
  57. // Tag byte
  58. // Value string
  59. // }
  60. // var sField []Field
  61. // tmp := string(r.buf[2 : len(r.buf)-1])
  62. // //0x01 字段分割
  63. // strS := strings.Split(tmp, string([]byte{0x01}))
  64. // for _, v := range strS {
  65. // //0x02 值分割
  66. // split := strings.Split(v, string([]byte{0x02}))
  67. // if len(split) != 2 {
  68. // break
  69. // }
  70. // d := Field{
  71. // Tag: ([]byte(split[0]))[0],
  72. // Value: split[1],
  73. // }
  74. // sField = append(sField, d)
  75. // }
  76. // for _, v := range sField {
  77. // log.Printf("0x%0x %s\n", v.Tag, v.Value)
  78. // }
  79. // }