EquipmentInfoService.py 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. # -*- encoding: utf-8 -*-
  2. """
  3. @File : EquipmentInfoService.py
  4. @Time : 2022/4/14 17:28
  5. @Author : stephen
  6. @Email : zhangdongming@asj6.wecom.work
  7. @Software: PyCharm
  8. """
  9. import logging
  10. from Model.models import EquipmentInfoMonday, EquipmentInfoTuesday, EquipmentInfoWednesday, EquipmentInfoThursday, \
  11. EquipmentInfoFriday, EquipmentInfoSaturday, EquipmentInfoSunday
  12. from Object.utils import LocalDateTimeUtil
  13. from django.db import transaction
  14. class EquipmentInfoService:
  15. @staticmethod
  16. def get_equipment_info_obj(dt, **kwargs):
  17. """
  18. 根据日期判断是星期几,返回相应的对象实例
  19. @param dt: 日期 例:2022-03-03
  20. @param kwargs: 设备信息属性值
  21. @return: 星期一至星期天equipment_info对象实例
  22. """
  23. week = LocalDateTimeUtil.date_to_week(dt)
  24. equipment_info = None
  25. if week == 1:
  26. equipment_info = EquipmentInfoMonday(**kwargs)
  27. elif week == 2:
  28. equipment_info = EquipmentInfoTuesday(**kwargs)
  29. elif week == 3:
  30. equipment_info = EquipmentInfoWednesday(**kwargs)
  31. elif week == 4:
  32. equipment_info = EquipmentInfoThursday(**kwargs)
  33. elif week == 5:
  34. equipment_info = EquipmentInfoFriday(**kwargs)
  35. elif week == 6:
  36. equipment_info = EquipmentInfoSaturday(**kwargs)
  37. elif week == 7:
  38. equipment_info = EquipmentInfoSunday(**kwargs)
  39. return equipment_info
  40. @staticmethod
  41. def equipment_info_bulk_create(week_val, equipment_info_list):
  42. """
  43. 根据week_val判断,进行表对象选择存储
  44. @param week_val: 星期一至星期天,int类型
  45. @param equipment_info_list: 设备信息实例列表
  46. @return: True or False
  47. """
  48. try:
  49. with transaction.atomic():
  50. if equipment_info_list and len(equipment_info_list) > 0:
  51. if week_val == 0:
  52. return False
  53. if week_val == 1:
  54. EquipmentInfoMonday.objects.bulk_create(equipment_info_list)
  55. elif week_val == 2:
  56. EquipmentInfoTuesday.objects.bulk_create(equipment_info_list)
  57. elif week_val == 3:
  58. EquipmentInfoWednesday.objects.bulk_create(equipment_info_list)
  59. elif week_val == 4:
  60. EquipmentInfoThursday.objects.bulk_create(equipment_info_list)
  61. elif week_val == 5:
  62. EquipmentInfoFriday.objects.bulk_create(equipment_info_list)
  63. elif week_val == 6:
  64. EquipmentInfoSaturday.objects.bulk_create(equipment_info_list)
  65. elif week_val == 7:
  66. EquipmentInfoSunday.objects.bulk_create(equipment_info_list)
  67. return True
  68. return False
  69. except Exception as e:
  70. er_log = logging.getLogger('django')
  71. er_log.exception(repr(e))
  72. er_log.error(repr(e))
  73. return False