金蝶云服务使用lambda分享

金蝶云服务使用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
否则 空字符
)
否则 空字符

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值