from calculators import RoundMethod from calculators.asphalt_domestic import AsphaltDomesticCalculator from calculators.asphalt_imported import AsphaltImportedCalculator from calculators.cement_325 import Cement325Calculator from calculators.cement_425 import Cement425Calculator from calculators.modifier import ModifierCalculator from calculators.oil_0 import Oil0Calculator from calculators.oil_89 import Oil89Calculator from calculators.oil_92 import Oil92Calculator from calculators.steel_plate import SteelPlateCalculator from calculators.steel_rebar_300 import Reber300Calculator from calculators.steel_rebar_400 import Reber400Calculator from calculators.steel_section import SteelSectionCalculator from calculators.steel_strand import SteelStrandCalculator from calculators.asphalt_domestic_modifier import AsphaltDomesticModifierCalculator from calculators.asphalt_imported_modifier import AsphaltImportedModifierCalculator def calculate(year=2023, month=8): """ 计算生成趋势表 """ from calculators import Calculator for round_bit, round_method, material_id, name, spec, unit in [ # 趋势表 [0, RoundMethod.normal, '2001001', 'HPB300钢筋', '', 't'], [0, RoundMethod.normal, '2001002', 'HRB400钢筋', '', 't'], [0, RoundMethod.normal, '2001008', '钢绞线', '普通,无松弛,Φ15.24', 't'], [0, RoundMethod.normal, '2003004', '型钢', '工字钢, 角钢 Ⅰ20', 't'], [0, RoundMethod.normal, '2003005', '钢板', 'A3, δ=5~40mm', 't'], [0, RoundMethod.normal, '2003005001', '钢板', 'Q355', 't'], [0, RoundMethod.normal, '3001001002', '石油沥青', '国产', 't'], [0, RoundMethod.normal, '3001001001', '石油沥青', '进口', 't'], [0, RoundMethod.normal, '3001002002', '改性石油沥青', '进口', 't'], [0, RoundMethod.normal, '3001002001', '改性石油沥青', '国产', 't'], [2, RoundMethod.none, '3003002001', '汽油', '89#', 'kg'], [2, RoundMethod.none, '3003002002', '汽油', '92#', 'kg'], [2, RoundMethod.none, '3003003', '柴油', '0#', 'kg'], [0, RoundMethod.normal, '5509001', '32.5级水泥', '32.5', 't'], [0, RoundMethod.normal, '5509002', '42.5级水泥', '32.5', 't'], [0, RoundMethod.normal, '5509003', '52.5级水泥', '52.5', 't'], # 直接来自调查表 todo 可通过忽略调查表以外的查询 来加快计算进程 [0, RoundMethod.normal, '2001003', '冷轧带肋钢筋网', '', 't'], [0, RoundMethod.normal, '2001006', '预应力粗钢筋', '', 't'], [0, RoundMethod.normal, '2001013', '高强钢丝', 'Φ5mm预应力用碳素钢丝', 't'], [0, RoundMethod.normal, '2001019', '钢丝绳', '股丝6-7×19mm(非镀锌)', 't'], [0, RoundMethod.normal, '2001025', '钢板网', '网眼尺寸25 * 76mm', 'm2'], [0, RoundMethod.normal, '2001026', '铁丝编织网', '镀锌铁丝(包括加强钢丝、花蓝螺丝)', 'm2'], [0, RoundMethod.normal, '2003006', '圆钢', 'Φ40mm', 't'], [0, RoundMethod.normal, '2003007', '钢轨', '43-50kg / m', 't'], [0, RoundMethod.normal, '2003012', '镀锌钢板', '厚度1-3mm', 't'], [0, RoundMethod.normal, '2003008', '钢管', '无缝钢管', 't'], [0, RoundMethod.normal, '2003009', '镀锌钢管', '外径15-200mm, 壁厚2.75-4.5mm', 't'], [0, RoundMethod.normal, '2003015', '钢管立柱', '', 't'], [0, RoundMethod.normal, '2003016', '型钢立柱', '镀锌(包括斜撑)', 't'], [0, RoundMethod.normal, '2003017001', '波形钢板(双波)', '双波 镀锌(包括端头板、撑架)', 't'], [0, RoundMethod.normal, '2003017002', '波形钢板(三波)', '三波 镀锌(包括端头板、撑架)', 't'], [0, RoundMethod.normal, '2003021', '钢管桩', '', 't'], [0, RoundMethod.normal, '2003022', '钢护筒', '', 't'], [0, RoundMethod.normal, '2004004', '镀锌无缝钢管', '热浸镀锌,外径152以上', 't'], [1, RoundMethod.none, '2005002', '不锈钢板', '厚度2-3mm', 'kg'], [1, RoundMethod.none, '2009028', '铁件', '包括扒钉、螺栓、拉杆、夹板', 'kg'], [1, RoundMethod.none, '2009033', '铸铁管', '', 'kg'], [2, RoundMethod.none, '3003001', '重油', '', 'kg'], [0, RoundMethod.normal, '4003001001', '杉原木', '二等材长4m, Φ14-18cm', 'm3'], [0, RoundMethod.normal, '4003001002', '松原木', '二等材Φ22-28cm长4-5m', 'm3'], [0, RoundMethod.normal, '4003002001', '锯材', '杉板料', 'm3'], [0, RoundMethod.normal, '4003002002', '锯材', '松板料', 'm3'], [0, RoundMethod.normal, '4005001', '毛竹', 'Φ=60mm, L≥6m;Φ=75~90mm, L≥6m', '根'], [1, RoundMethod.none, '5005001', '乳化炸药', '', 'kg'], [1, RoundMethod.none, '5005002', '硝铵炸药', '1号、2号岩石硝铵炸药', 'kg'], [1, RoundMethod.none, '5005003', '导火线', '120s/m', 'm'], [1, RoundMethod.none, '5005006', '普通雷管', '8号钢管', '个'], [1, RoundMethod.none, '5005007', '电雷管', '6号瞬发电雷管, 带脚线1.5m', '个'], [1, RoundMethod.none, '5005009', '导爆索', '爆速6000~7000m/s', 'm'], [1, RoundMethod.none, '5006001', '工业数码电子雷管', '带电子芯片,带脚线7m', '个'], [1, RoundMethod.none, '5006002', '引爆母线', '铜线φ0.5mm', 'm'], [2, RoundMethod.none, '5007003001', '土工格栅', '宽6m,聚乙烯单向、双向拉伸、聚丙烯双向、玻璃纤维', 'm2'], [1, RoundMethod.none, '5009002', '油漆', '普通调和漆', 'kg'], [0, RoundMethod.none, '5506001', '路缘石', '花岗岩', 'm3'], [1, RoundMethod.none, '6001002', '四氟板式橡胶组合支座', 'GJZF4系列、GYZF4系列', 'dm3'], [1, RoundMethod.none, '6001003', '板式橡胶支座', 'GJZ系列、GYZ系列', 'dm3'], [0, RoundMethod.normal, '6001059', '盆式橡胶支座', '2500KN(双向)', '套'], [0, RoundMethod.normal, '6001071', '盆式橡胶支座', '5000KN(双向)', '套'], [0, RoundMethod.normal, '6001080', '盆式橡胶支座', '8000KN(双向)', '套'], [0, RoundMethod.normal, '6001086', '盆式橡胶支座', '10000KN(双向)', '套'], [0, RoundMethod.normal, '6001089', '盆式橡胶支座', '双向12500KN', '套'], [0, RoundMethod.normal, '6001092', '盆式橡胶支座', '双向15000KN', '套'], [0, RoundMethod.normal, '6002001', '橡胶护舷', 'H300×L1000', '套'], [0, RoundMethod.normal, '6002002', '橡胶护舷', 'H300×L1500', '套'], [0, RoundMethod.normal, '6002003', '橡胶护舷', 'H300×L2000', '套'], [0, RoundMethod.normal, '6002004', '鼓型橡胶护舷', 'SC1000H', '套'], [0, RoundMethod.normal, '6002005', '鼓型橡胶护舷', 'SC1600H', '套'], [0, RoundMethod.normal, '6002006', '鼓型橡胶护舷', 'SC2000H', '套'], [0, RoundMethod.normal, '6003001', '模数式伸缩缝', '80型', '套'], [0, RoundMethod.normal, '6003003', '模数式伸缩缝', '160型', '套'], [0, RoundMethod.normal, '6005005', '钢绞线群锚(3孔)', '包括夹片、锚垫板和螺旋筋', '套'], [0, RoundMethod.normal, '6005009', '钢绞线群锚(7孔)', '包括夹片、锚垫板和螺旋筋', '套'], [0, RoundMethod.normal, '6005015', '钢绞线群锚(15孔)', '包括夹片、锚垫板和螺旋筋', '套'], [0, RoundMethod.normal, '6007002', '铝合金标志', '纯铝板1100', 't'], ]: calculator = Calculator(year=year, month=month) calculator.name = name calculator.material_id = material_id calculator.unit = unit calculator.spec = spec calculator.round_bit = round_bit calculator.round_method = round_method _result = calculator.run() calculator.save() print(_result) # # todo-1 价格计算触发器 # for Calculator in [ # AsphaltDomesticCalculator, # AsphaltImportedCalculator, # Cement325Calculator, # Cement425Calculator, # Oil0Calculator, # Oil89Calculator, # Oil92Calculator, # SteelPlateCalculator, # Reber300Calculator, # Reber400Calculator, # SteelSectionCalculator, # SteelStrandCalculator, # # ModifierCalculator, # AsphaltDomesticModifierCalculator, # AsphaltImportedModifierCalculator, # ]: # calculator = Calculator(year=year, month=month) # _result = calculator.run() # calculator.save() # print(_result) if __name__ == '__main__': from core.factory import ClientApp with ClientApp().app_context(): # for i in range(2, 12): # calculate(2022, i+1) # for i in range(0, 12): # calculate(2023, i+1) for i in range(6-1, 10): calculate(2024, i+1)