金蝶云服务使用lambda分享
一.按条件汇总单据体数量至表头
(单据体复选框已勾选的“确认订单量”字段汇总至表头“汇总”字段)。
大致步骤:
1.表头“汇总”字段设置值更新
F_lcs_Decimal =sum(map(lambda x:(x.FFirmQty if x.FChoose==True else 0),FBatchEntity))
2.单据体实体服务规则设置调用字段更新服务,调用“汇总”字段
(本次测试案例因为存在索引为0的行需要点击两下才能取消勾选的bug,所以调用字段更新服务全部勾选触发,这样计算就不会有问题。
按具体场景选择配置)
二.保存检验,单据体某条件下某字段必填。
(单据体“费用项目”=‘FYXM02_SYS’,则“发票号”字段和“编码后缀”字段必填)
len(filter(lambda x:x.FTRAVELTYPE.FNumber<>‘CLLX007’ and ((’’ if x.F_ORA_TEXTNone else x.F_ORA_TEXT.strip())=’’ or (’’ if x.F_ORA_TEXT1None else x.F_ORA_TEXT1.strip())=’’), FEntity))>0
三.把单据体第一行某字段更新至表头某字段
F_lcs_Base1=map(lambda x:x.F_lcs_Base,FEntity)[0]
四.当单据体只有一行数据时,把单据体第一行某字段更新至表头某字段;当单据体多行数据时,表头某字段清空
F_lcs_Base1=map(lambda x:x.F_lcs_Base.Id if len(FEntity)==1 else 0,FEntity)[0]
五.下拉框数据计算设置(值更新获取到的是枚举值并非枚举名称)
len() 返回对象(字符、列表、元组等)长度或项目个数。
map() 会根据提供的函数对指定序列做映射。
filter() 函数用于过滤序列,过滤掉不符合条件的元素,返回由符合条件元素组成的新列表。
set() 函数创建一个无序不重复元素集,可进行关系测试,删除重复数据,还可以计算交集、差集、并集等。
五
F_asdg_Integer =
0 if F_asdg_Combo.strip()=="" else
(float(FQty)/float(F_asdg_Combo) if float(FQty)%float(F_asdg_Combo)==0 else float(FQty)/float(F_asdg_Combo)+0.5)
float(FQty)/float(F_asdg_Combo) if float(FQty)%float(F_asdg_Combo)==0 else float(FQty)/float(F_asdg_Combo)+0.5
如果:数量/包装规格 余数为0
则 桶数=数量/包装规格 整数控件自动四舍五入
否则 桶数=数量/包装规格+0.5 整数控件自动四舍五
如果:包装规格为空
则 桶数=0
否则 桶数=以上公式
Strip 去除前后空格
Float 转化为小数类型
% 除法取余数
六、携带供应商联系人单据体的默认联系人
(因联系人单据体与联系人基础资料公用数据表,所以获取行ID即可赋值基础资料/同理供应商联系人单据体文本信息也可用此方法获取)
FBContactId=
(
map(lambda x:x[‘Id’],filter(lambda x:x[‘IsDefault’]==True,FBParty.SupplierContact))[0]
if len(filter(lambda x:x[‘IsDefault’]==True,FBParty.SupplierContact))>0 else ‘’
)
if FBParty<>None else ‘’
如果 供应商<>None
则
(
map(lambda x:x[‘Id’],filter(lambda x:x[‘IsDefault’]==True,FBParty.SupplierContact))[0]
if len(filter(lambda x:x[‘IsDefault’]==True,FBParty.SupplierContact))>0 else ‘’
如果 供应商联系人列表勾选默认的行数>0
则 过滤出供应商列表勾选默认联系人的集合,并取第一行的ID
否则 空字符
)
否则 空字符