1.修改刀具标准库同步6个物料的方法

2.刀具基础参数的刃数和刀片的刃数两个字段新增选项,新增active字段,xml中修改适配刀片型号字段
This commit is contained in:
jinling.yang
2024-01-03 17:41:44 +08:00
parent 7f050b62f9
commit da8cbe4cce
3 changed files with 239 additions and 221 deletions

View File

@@ -14,8 +14,8 @@ class ToolMaterialsBasicParameters(models.Model):
# 整体式刀具参数
total_length = fields.Float('总长度(mm)')
blade_number = fields.Selection(
[('2', '2'), ('3', '3'), ('4', '4'), ('5', '5'), ('6', '6'), ('7', '7'), ('8', '8')],
string='刃数(个)')
[('0', '0'), ('2', '2'), ('3', '3'), ('4', '4'), ('5', '5'), ('6', '6'), ('7', '7'), ('8', '8')],
string='刃数(个)', default='0')
neck_diameter = fields.Float('颈部直径(mm)')
neck_length = fields.Float('颈部长度(mm)')
handle_diameter = fields.Float('柄部直径(mm)')
@@ -47,9 +47,10 @@ class ToolMaterialsBasicParameters(models.Model):
('UNJ全牙型', 'UNJ全牙型'), ('DIN405圆牙型', 'DIN405圆牙型'), ('ACME梯形', 'ACME梯形'),
('石油管螺纹刀片', '石油管螺纹刀片'), ('矮牙ACME梯形', '矮牙ACME梯形'),
('Trapeze30° 103', 'Trapeze30° 103')], string='刀片牙型', default='')
blade_blade_number = fields.Selection([('1', '1'), ('2', '2'), ('3', '3'), ('4', '4'), ('5', '5'), ('6', '6'),
('7', '7'), ('8', '8'), ('9', '9'), ('10', '10')],
string='刀片的刃数(个)')
blade_blade_number = fields.Selection(
[('0', '0'), ('1', '1'), ('2', '2'), ('3', '3'), ('4', '4'), ('5', '5'), ('6', '6'), ('7', '7'), ('8', '8'),
('9', '9'), ('10', '10')],
string='刀片的刃数(个)', default='0')
main_included_angle = fields.Integer('主偏角(°)')
top_angle = fields.Integer('顶角(°)')
blade_tip_dip_angle = fields.Integer('刀尖倾角(°)')
@@ -133,6 +134,7 @@ class ToolMaterialsBasicParameters(models.Model):
domain="[('cutting_tool_material_id.name', '=', '刀柄')]",
string='适用刀柄型号'
)
active = fields.Boolean(string='有效', default=True)
def _json_integral_tool_basic_param(self, obj):
integral_tool_basic_param_str = (0, '', {

View File

@@ -73,7 +73,7 @@
<field name="is_cooling_hole" />
<field name="locating_slot_code" />
<field name="installing_structure"/>
<field name="blade_ids"/>
<field name="blade_id"/>
<field name="tool_shim" />
<field name="cotter_pin" />
<field name="pressing_plate"/>

View File

@@ -2123,10 +2123,12 @@ class CuttingToolBasicParameters(models.Model):
r = r.json()
result = json.loads(r['result'])
if result['status'] == 1:
for item in result['cutting_tool_basic_parameters_all_list']:
for integral_tool_item in item['basic_parameters_integral_tool']:
basic_parameters_integral_tool_list = json.loads(
result['cutting_tool_basic_parameters_all_list']['basic_parameters_integral_tool'])
if basic_parameters_integral_tool_list:
for integral_tool_item in basic_parameters_integral_tool_list:
integral_tool = self.search([('code', '=', integral_tool_item['code'])])
if integral_tool:
if not integral_tool:
self.create({
'name': integral_tool_item['name'],
'code': integral_tool_item['code'],
@@ -2155,7 +2157,6 @@ class CuttingToolBasicParameters(models.Model):
else:
self.write({
'name': integral_tool_item['name'],
'cutting_tool_type': integral_tool_item['cutting_tool_type'],
'total_length': integral_tool_item['total_length'],
'blade_diameter': integral_tool_item['blade_diameter'],
'blade_length': integral_tool_item['blade_length'],
@@ -2174,9 +2175,12 @@ class CuttingToolBasicParameters(models.Model):
'cutting_depth': integral_tool_item['cutting_depth_max'],
'active': integral_tool_item['active'],
})
for blade_item in item['basic_parameters_blade']:
basic_parameters_blade_list = json.loads(
result['cutting_tool_basic_parameters_all_list']['basic_parameters_blade'])
if basic_parameters_blade_list:
for blade_item in basic_parameters_blade_list:
blade = self.search([('code', '=', blade_item['code'])])
if blade:
if not blade:
self.create({
'name': blade_item['name'],
'code': blade_item['code'],
@@ -2186,7 +2190,6 @@ class CuttingToolBasicParameters(models.Model):
'factory_short_name']))]).id,
'length': blade_item['length'],
'thickness': blade_item['thickness'],
'width': blade_item['width'],
'cutting_blade_length': blade_item['cutting_blade_length'],
'relief_angle': blade_item['relief_angle'],
'blade_tip_circular_arc_radius': blade_item['radius_tip_re'],
@@ -2201,10 +2204,8 @@ class CuttingToolBasicParameters(models.Model):
'blade_width': blade_item['blade_width'],
'main_included_angle': blade_item['edge_angle'],
'top_angle': blade_item['top_angle'],
'blade_tip_dip_angle': blade_item['blade_tip_dip_angle'],
'side_cutting_edge_angle': blade_item['side_cutting_edge_angle'],
'thread_model': '' if not blade_item['thread_type'] else blade_item['thread_type'],
'thread_num': blade_item['thread_num'],
'thread_num': blade_item['threads_per_inch'],
'blade_tip_height_tolerance': blade_item['tip_height_tolerance'],
'inscribed_circle_tolerance': blade_item['internal_circle_tolerance'],
'thickness_tolerance': blade_item['thickness_tolerance'],
@@ -2230,18 +2231,19 @@ class CuttingToolBasicParameters(models.Model):
'blade_width': blade_item['blade_width'],
'main_included_angle': blade_item['edge_angle'],
'top_angle': blade_item['top_angle'],
'blade_tip_dip_angle': blade_item['blade_tip_dip_angle'],
'side_cutting_edge_angle': blade_item['side_cutting_edge_angle'],
'thread_model': '' if not blade_item['thread_type'] else blade_item['thread_type'],
'thread_num': blade_item['thread_num'],
'thread_num': blade_item['threads_per_inch'],
'blade_tip_height_tolerance': blade_item['tip_height_tolerance'],
'inscribed_circle_tolerance': blade_item['internal_circle_tolerance'],
'thickness_tolerance': blade_item['thickness_tolerance'],
'active': blade_item['active'],
})
for chuck_item in item['basic_parameters_chuck']:
basic_parameters_chuck_list = json.loads(
result['cutting_tool_basic_parameters_all_list']['basic_parameters_chuck'])
if basic_parameters_chuck_list:
for chuck_item in basic_parameters_chuck_list:
chuck = self.search([('code', '=', chuck_item['code'])])
if chuck:
if not chuck:
self.create({
'name': chuck_item['name'],
'code': chuck_item['code'],
@@ -2260,9 +2262,6 @@ class CuttingToolBasicParameters(models.Model):
'top_diameter': chuck_item['top_diameter'],
'weight': chuck_item['weight'],
'max_load_capacity': chuck_item['load_capacity_max'],
'handle_id': self.env['sf.cutting_tool.standard.library'].search(
[('code', '=', chuck_item['fit_knife_handle_code'].replace("JKM", result[
'factory_short_name']))]).id,
'cooling_jacket': chuck_item['cooling_sleeve_model'],
'active': chuck_item['active'],
})
@@ -2280,15 +2279,15 @@ class CuttingToolBasicParameters(models.Model):
'top_diameter': chuck_item['top_diameter'],
'weight': chuck_item['weight'],
'max_load_capacity': chuck_item['load_capacity_max'],
'handle_id': self.env['sf.cutting_tool.standard.library'].search(
[('code', '=', chuck_item['fit_knife_handle_code'].replace("JKM", result[
'factory_short_name']))]).id,
'cooling_jacket': chuck_item['cooling_sleeve_model'],
'active': chuck_item['active'],
})
for cutter_arbor_item in item['basic_parameters_cutter_arbor']:
basic_parameters_cutter_arbor_list = json.loads(
result['cutting_tool_basic_parameters_all_list']['basic_parameters_cutter_arbor'])
if basic_parameters_cutter_arbor_list:
for cutter_arbor_item in basic_parameters_cutter_arbor_list:
cutter_arbor = self.search([('code', '=', cutter_arbor_item['code'])])
if cutter_arbor:
if not cutter_arbor:
self.create({
'name': cutter_arbor_item['name'],
'code': cutter_arbor_item['code'],
@@ -2308,11 +2307,11 @@ class CuttingToolBasicParameters(models.Model):
'cutting_depth': cutter_arbor_item['cutting_depth_max'],
'min_machining_aperture': cutter_arbor_item['machining_aperture_min'],
'install_blade_tip_num': cutter_arbor_item['number_blade_installed'],
'cutting_blade_model': cutter_arbor_item['cutting_blade_model'],
'is_cooling_hole': cutter_arbor_item['is_cooling_hole'],
'locating_slot_code': cutter_arbor_item['locator_slot_code'],
'installing_structure': cutter_arbor_item['installing_structure'],
'blade_id': self.env['sf.cutting_tool.standard.library'].search(
'installing_structure': cutter_arbor_item['mounting_structure'],
'blade_id': False if not cutter_arbor_item['fit_blade_model_code'] else self.env[
'sf.cutting_tool.standard.library'].search(
[('code', '=', cutter_arbor_item['fit_blade_model_code'].replace("JKM", result[
'factory_short_name']))]).id,
'tool_shim': cutter_arbor_item['fit_knife_pad_model'],
@@ -2337,11 +2336,11 @@ class CuttingToolBasicParameters(models.Model):
'cutting_depth': cutter_arbor_item['cutting_depth_max'],
'min_machining_aperture': cutter_arbor_item['machining_aperture_min'],
'install_blade_tip_num': cutter_arbor_item['number_blade_installed'],
'cutting_blade_model': cutter_arbor_item['cutting_blade_model'],
'is_cooling_hole': cutter_arbor_item['is_cooling_hole'],
'locating_slot_code': cutter_arbor_item['locator_slot_code'],
'installing_structure': cutter_arbor_item['installing_structure'],
'blade_id': self.env['sf.cutting_tool.standard.library'].search(
'installing_structure': cutter_arbor_item['mounting_structure'],
'blade_id': False if not cutter_arbor_item['fit_blade_model_code'] else self.env[
'sf.cutting_tool.standard.library'].search(
[('code', '=', cutter_arbor_item['fit_blade_model_code'].replace("JKM", result[
'factory_short_name']))]).id,
'tool_shim': cutter_arbor_item['fit_knife_pad_model'],
@@ -2351,9 +2350,12 @@ class CuttingToolBasicParameters(models.Model):
'spanner': cutter_arbor_item['fit_wrench_model'],
'active': cutter_arbor_item['active'],
})
for cutter_head_item in item['basic_parameters_cutter_head']:
basic_parameters_cutter_head_list = json.loads(
result['cutting_tool_basic_parameters_all_list']['basic_parameters_cutter_head'])
if basic_parameters_cutter_head_list:
for cutter_head_item in basic_parameters_cutter_head_list:
cutter_head = self.search([('code', '=', cutter_head_item['code'])])
if cutter_head:
if not cutter_head:
self.create({
'name': cutter_head_item['name'],
'code': cutter_head_item['code'],
@@ -2369,8 +2371,9 @@ class CuttingToolBasicParameters(models.Model):
'blade_length': cutter_head_item['blade_length'],
'cutting_depth': cutter_head_item['cutting_depth_max'],
'main_included_angle': cutter_head_item['edge_angle'],
'installing_structure': cutter_head_item['installing_structure'],
'blade_id': self.env['sf.cutting_tool.standard.library'].search(
'installing_structure': cutter_head_item['mounting_structure'],
'blade_id': False if not cutter_head_item['fit_blade_model_code'] else self.env[
'sf.cutting_tool.standard.library'].search(
[('code', '=', cutter_head_item['fit_blade_model_code'].replace("JKM", result[
'factory_short_name']))]).id,
'screw': cutter_head_item['fit_screw_model'],
@@ -2381,7 +2384,7 @@ class CuttingToolBasicParameters(models.Model):
})
else:
self.write({
'name': cutter_arbor_item['name'],
'name': cutter_head_item['name'],
'install_blade_tip_num': cutter_head_item['number_blade_installed'],
'blade_diameter': cutter_head_item['blade_diameter'],
'cutter_head_diameter': cutter_head_item['cutter_diameter'],
@@ -2390,8 +2393,9 @@ class CuttingToolBasicParameters(models.Model):
'blade_length': cutter_head_item['blade_length'],
'cutting_depth': cutter_head_item['cutting_depth_max'],
'main_included_angle': cutter_head_item['edge_angle'],
'installing_structure': cutter_head_item['installing_structure'],
'blade_id': self.env['sf.cutting_tool.standard.library'].search(
'installing_structure': cutter_head_item['mounting_structure'],
'blade_id': False if not cutter_head_item['fit_blade_model_code'] else self.env[
'sf.cutting_tool.standard.library'].search(
[('code', '=', cutter_head_item['fit_blade_model_code'].replace("JKM", result[
'factory_short_name']))]).id,
'screw': cutter_head_item['fit_screw_model'],
@@ -2400,10 +2404,12 @@ class CuttingToolBasicParameters(models.Model):
'locating_slot_code': cutter_head_item['locator_slot_code'],
'active': cutter_head_item['active'],
})
for knife_handle_item in item['basic_parameters_knife_handle']:
basic_parameters_knife_handle_list = json.loads(
result['cutting_tool_basic_parameters_all_list']['basic_parameters_knife_handle'])
if basic_parameters_knife_handle_list:
for knife_handle_item in basic_parameters_knife_handle_list:
knife_handle = self.search([('code', '=', knife_handle_item['code'])])
if knife_handle:
if not knife_handle:
self.create({
'name': knife_handle_item['name'],
'code': knife_handle_item['code'],
@@ -2428,9 +2434,6 @@ class CuttingToolBasicParameters(models.Model):
'screw': knife_handle_item['fit_wrench_model'],
'nut': knife_handle_item['fit_nut_model'],
'dynamic_balance_class': knife_handle_item['dynamic_balance_class'],
'chuck_id': self.env['sf.cutting_tool.standard.library'].search(
[('code', '=', knife_handle_item['fit_chuck_model_code'].replace("JKM", result[
'factory_short_name']))]).id,
'active': knife_handle_item['active'],
})
else:
@@ -2453,9 +2456,6 @@ class CuttingToolBasicParameters(models.Model):
'screw': knife_handle_item['fit_wrench_model'],
'nut': knife_handle_item['fit_nut_model'],
'dynamic_balance_class': knife_handle_item['dynamic_balance_class'],
'chuck_id': self.env['sf.cutting_tool.standard.library'].search(
[('code', '=', knife_handle_item['fit_chuck_model_code'].replace("JKM", result[
'factory_short_name']))]).id,
'active': knife_handle_item['active'],
})
else:
@@ -2469,10 +2469,12 @@ class CuttingToolBasicParameters(models.Model):
r = r.json()
result = json.loads(r['result'])
if result['status'] == 1:
for item in result['cutting_tool_basic_parameters_yesterday_list']:
for integral_tool_item in item['basic_parameters_integral_tool']:
basic_parameters_integral_tool_list = json.loads(
result['cutting_tool_basic_parameters_all_list']['basic_parameters_integral_tool'])
if basic_parameters_integral_tool_list:
for integral_tool_item in basic_parameters_integral_tool_list:
integral_tool = self.search([('code', '=', integral_tool_item['code'])])
if integral_tool:
if not integral_tool:
self.create({
'name': integral_tool_item['name'],
'code': integral_tool_item['code'],
@@ -2498,10 +2500,12 @@ class CuttingToolBasicParameters(models.Model):
'cutting_depth': integral_tool_item['cutting_depth_max'],
'active': integral_tool_item['active'],
})
else:
if integral_tool_item['active'] is False:
integral_tool.write({'active': False})
else:
self.write({
'name': integral_tool_item['name'],
'cutting_tool_type': integral_tool_item['cutting_tool_type'],
'total_length': integral_tool_item['total_length'],
'blade_diameter': integral_tool_item['blade_diameter'],
'blade_length': integral_tool_item['blade_length'],
@@ -2520,9 +2524,12 @@ class CuttingToolBasicParameters(models.Model):
'cutting_depth': integral_tool_item['cutting_depth_max'],
'active': integral_tool_item['active'],
})
for blade_item in item['basic_parameters_blade']:
basic_parameters_blade_list = json.loads(
result['cutting_tool_basic_parameters_all_list']['basic_parameters_blade'])
if basic_parameters_blade_list:
for blade_item in basic_parameters_blade_list:
blade = self.search([('code', '=', blade_item['code'])])
if blade:
if not blade:
self.create({
'name': blade_item['name'],
'code': blade_item['code'],
@@ -2532,7 +2539,6 @@ class CuttingToolBasicParameters(models.Model):
'factory_short_name']))]).id,
'length': blade_item['length'],
'thickness': blade_item['thickness'],
'width': blade_item['width'],
'cutting_blade_length': blade_item['cutting_blade_length'],
'relief_angle': blade_item['relief_angle'],
'blade_tip_circular_arc_radius': blade_item['radius_tip_re'],
@@ -2547,21 +2553,21 @@ class CuttingToolBasicParameters(models.Model):
'blade_width': blade_item['blade_width'],
'main_included_angle': blade_item['edge_angle'],
'top_angle': blade_item['top_angle'],
'blade_tip_dip_angle': blade_item['blade_tip_dip_angle'],
'side_cutting_edge_angle': blade_item['side_cutting_edge_angle'],
'thread_model': '' if not blade_item['thread_type'] else blade_item['thread_type'],
'thread_num': blade_item['thread_num'],
'thread_num': blade_item['threads_per_inch'],
'blade_tip_height_tolerance': blade_item['tip_height_tolerance'],
'inscribed_circle_tolerance': blade_item['internal_circle_tolerance'],
'thickness_tolerance': blade_item['thickness_tolerance'],
'active': blade_item['active'],
})
else:
if blade_item['active'] is False:
blade.write({'active': False})
else:
self.write({
'name': integral_tool_item['name'],
'name': blade_item['name'],
'length': blade_item['length'],
'thickness': blade_item['thickness'],
'width': blade_item['width'],
'cutting_blade_length': blade_item['cutting_blade_length'],
'relief_angle': blade_item['relief_angle'],
'blade_tip_circular_arc_radius': blade_item['radius_tip_re'],
@@ -2576,18 +2582,19 @@ class CuttingToolBasicParameters(models.Model):
'blade_width': blade_item['blade_width'],
'main_included_angle': blade_item['edge_angle'],
'top_angle': blade_item['top_angle'],
'blade_tip_dip_angle': blade_item['blade_tip_dip_angle'],
'side_cutting_edge_angle': blade_item['side_cutting_edge_angle'],
'thread_model': '' if not blade_item['thread_type'] else blade_item['thread_type'],
'thread_num': blade_item['thread_num'],
'thread_num': blade_item['threads_per_inch'],
'blade_tip_height_tolerance': blade_item['tip_height_tolerance'],
'inscribed_circle_tolerance': blade_item['internal_circle_tolerance'],
'thickness_tolerance': blade_item['thickness_tolerance'],
'active': blade_item['active'],
})
for chuck_item in item['basic_parameters_chuck']:
basic_parameters_chuck_list = json.loads(
result['cutting_tool_basic_parameters_all_list']['basic_parameters_chuck'])
if basic_parameters_chuck_list:
for chuck_item in basic_parameters_chuck_list:
chuck = self.search([('code', '=', chuck_item['code'])])
if chuck:
if not chuck:
self.create({
'name': chuck_item['name'],
'code': chuck_item['code'],
@@ -2606,15 +2613,15 @@ class CuttingToolBasicParameters(models.Model):
'top_diameter': chuck_item['top_diameter'],
'weight': chuck_item['weight'],
'max_load_capacity': chuck_item['load_capacity_max'],
'handle_id': self.env['sf.cutting_tool.standard.library'].search(
[('code', '=', chuck_item['fit_knife_handle_code'].replace("JKM", result[
'factory_short_name']))]).id,
'cooling_jacket': chuck_item['cooling_sleeve_model'],
'active': chuck_item['active'],
})
else:
if chuck_item['active'] is False:
chuck.write({'active': False})
else:
self.write({
'name': integral_tool_item['name'],
'name': chuck_item['name'],
'er_size_model': chuck_item['size_model'],
'min_clamping_diameter': chuck_item['clamping_diameter_min'],
'max_clamping_diameter': chuck_item['clamping_diameter_max'],
@@ -2626,15 +2633,15 @@ class CuttingToolBasicParameters(models.Model):
'top_diameter': chuck_item['top_diameter'],
'weight': chuck_item['weight'],
'max_load_capacity': chuck_item['load_capacity_max'],
'handle_id': self.env['sf.cutting_tool.standard.library'].search(
[('code', '=', chuck_item['fit_knife_handle_code'].replace("JKM", result[
'factory_short_name']))]).id,
'cooling_jacket': chuck_item['cooling_sleeve_model'],
'active': chuck_item['active'],
})
for cutter_arbor_item in item['basic_parameters_cutter_arbor']:
basic_parameters_cutter_arbor_list = json.loads(
result['cutting_tool_basic_parameters_all_list']['basic_parameters_cutter_arbor'])
if basic_parameters_cutter_arbor_list:
for cutter_arbor_item in basic_parameters_cutter_arbor_list:
cutter_arbor = self.search([('code', '=', cutter_arbor_item['code'])])
if cutter_arbor:
if not cutter_arbor:
self.create({
'name': cutter_arbor_item['name'],
'code': cutter_arbor_item['code'],
@@ -2654,11 +2661,11 @@ class CuttingToolBasicParameters(models.Model):
'cutting_depth': cutter_arbor_item['cutting_depth_max'],
'min_machining_aperture': cutter_arbor_item['machining_aperture_min'],
'install_blade_tip_num': cutter_arbor_item['number_blade_installed'],
'cutting_blade_model': cutter_arbor_item['cutting_blade_model'],
'is_cooling_hole': cutter_arbor_item['is_cooling_hole'],
'locating_slot_code': cutter_arbor_item['locator_slot_code'],
'installing_structure': cutter_arbor_item['installing_structure'],
'blade_id': self.env['sf.cutting_tool.standard.library'].search(
'installing_structure': cutter_arbor_item['mounting_structure'],
'blade_id': False if not cutter_arbor_item['fit_blade_model_code'] else self.env[
'sf.cutting_tool.standard.library'].search(
[('code', '=', cutter_arbor_item['fit_blade_model_code'].replace("JKM", result[
'factory_short_name']))]).id,
'tool_shim': cutter_arbor_item['fit_knife_pad_model'],
@@ -2668,6 +2675,9 @@ class CuttingToolBasicParameters(models.Model):
'spanner': cutter_arbor_item['fit_wrench_model'],
'active': cutter_arbor_item['active'],
})
else:
if cutter_arbor_item['active'] is False:
cutter_arbor.write({'active': False})
else:
self.write({
'name': cutter_arbor_item['name'],
@@ -2683,11 +2693,11 @@ class CuttingToolBasicParameters(models.Model):
'cutting_depth': cutter_arbor_item['cutting_depth_max'],
'min_machining_aperture': cutter_arbor_item['machining_aperture_min'],
'install_blade_tip_num': cutter_arbor_item['number_blade_installed'],
'cutting_blade_model': cutter_arbor_item['cutting_blade_model'],
'is_cooling_hole': cutter_arbor_item['is_cooling_hole'],
'locating_slot_code': cutter_arbor_item['locator_slot_code'],
'installing_structure': cutter_arbor_item['installing_structure'],
'blade_id': self.env['sf.cutting_tool.standard.library'].search(
'installing_structure': cutter_arbor_item['mounting_structure'],
'blade_id': False if not cutter_arbor_item['fit_blade_model_code'] else self.env[
'sf.cutting_tool.standard.library'].search(
[('code', '=', cutter_arbor_item['fit_blade_model_code'].replace("JKM", result[
'factory_short_name']))]).id,
'tool_shim': cutter_arbor_item['fit_knife_pad_model'],
@@ -2697,9 +2707,12 @@ class CuttingToolBasicParameters(models.Model):
'spanner': cutter_arbor_item['fit_wrench_model'],
'active': cutter_arbor_item['active'],
})
for cutter_head_item in item['basic_parameters_cutter_head']:
basic_parameters_cutter_head_list = json.loads(
result['cutting_tool_basic_parameters_all_list']['basic_parameters_cutter_head'])
if basic_parameters_cutter_head_list:
for cutter_head_item in basic_parameters_cutter_head_list:
cutter_head = self.search([('code', '=', cutter_head_item['code'])])
if cutter_head:
if not cutter_head:
self.create({
'name': cutter_head_item['name'],
'code': cutter_head_item['code'],
@@ -2715,8 +2728,9 @@ class CuttingToolBasicParameters(models.Model):
'blade_length': cutter_head_item['blade_length'],
'cutting_depth': cutter_head_item['cutting_depth_max'],
'main_included_angle': cutter_head_item['edge_angle'],
'installing_structure': cutter_head_item['installing_structure'],
'blade_id': self.env['sf.cutting_tool.standard.library'].search(
'installing_structure': cutter_head_item['mounting_structure'],
'blade_id': False if not cutter_head_item['fit_blade_model_code'] else self.env[
'sf.cutting_tool.standard.library'].search(
[('code', '=', cutter_head_item['fit_blade_model_code'].replace("JKM", result[
'factory_short_name']))]).id,
'screw': cutter_head_item['fit_screw_model'],
@@ -2725,9 +2739,12 @@ class CuttingToolBasicParameters(models.Model):
'locating_slot_code': cutter_head_item['locator_slot_code'],
'active': cutter_head_item['active'],
})
else:
if cutter_head_item['active'] is False:
cutter_head.write({'active': False})
else:
self.write({
'name': cutter_arbor_item['name'],
'name': cutter_head_item['name'],
'install_blade_tip_num': cutter_head_item['number_blade_installed'],
'blade_diameter': cutter_head_item['blade_diameter'],
'cutter_head_diameter': cutter_head_item['cutter_diameter'],
@@ -2736,8 +2753,9 @@ class CuttingToolBasicParameters(models.Model):
'blade_length': cutter_head_item['blade_length'],
'cutting_depth': cutter_head_item['cutting_depth_max'],
'main_included_angle': cutter_head_item['edge_angle'],
'installing_structure': cutter_head_item['installing_structure'],
'blade_id': self.env['sf.cutting_tool.standard.library'].search(
'installing_structure': cutter_head_item['mounting_structure'],
'blade_id': False if not cutter_head_item['fit_blade_model_code'] else self.env[
'sf.cutting_tool.standard.library'].search(
[('code', '=', cutter_head_item['fit_blade_model_code'].replace("JKM", result[
'factory_short_name']))]).id,
'screw': cutter_head_item['fit_screw_model'],
@@ -2746,10 +2764,12 @@ class CuttingToolBasicParameters(models.Model):
'locating_slot_code': cutter_head_item['locator_slot_code'],
'active': cutter_head_item['active'],
})
for knife_handle_item in item['basic_parameters_knife_handle']:
basic_parameters_knife_handle_list = json.loads(
result['cutting_tool_basic_parameters_all_list']['basic_parameters_knife_handle'])
if basic_parameters_knife_handle_list:
for knife_handle_item in basic_parameters_knife_handle_list:
knife_handle = self.search([('code', '=', knife_handle_item['code'])])
if knife_handle:
if not knife_handle:
self.create({
'name': knife_handle_item['name'],
'code': knife_handle_item['code'],
@@ -2774,11 +2794,11 @@ class CuttingToolBasicParameters(models.Model):
'screw': knife_handle_item['fit_wrench_model'],
'nut': knife_handle_item['fit_nut_model'],
'dynamic_balance_class': knife_handle_item['dynamic_balance_class'],
'chuck_id': self.env['sf.cutting_tool.standard.library'].search(
[('code', '=', knife_handle_item['fit_chuck_model_code'].replace("JKM", result[
'factory_short_name']))]).id,
'active': knife_handle_item['active'],
})
else:
if knife_handle_item['active'] is False:
knife_handle.write({'active': False})
else:
self.write({
'name': knife_handle_item['name'],
@@ -2799,10 +2819,6 @@ class CuttingToolBasicParameters(models.Model):
'screw': knife_handle_item['fit_wrench_model'],
'nut': knife_handle_item['fit_nut_model'],
'dynamic_balance_class': knife_handle_item['dynamic_balance_class'],
'chuck_id': self.env['sf.cutting_tool.standard.library'].search(
[('code', '=', knife_handle_item['fit_chuck_model_code'].replace("JKM", result[
'factory_short_name']))]).id,
'active': knife_handle_item['active'],
})
else:
raise ValidationError("刀具物料基本参数认证未通过")