【Dynamics 365 FO】导入汇率以及在X++代码中使用这些汇率

商务合作请加微信:DingtalkCSM

首先我们需要先创建一个汇率提供方,Dyanmics 365官方为我们提供了三个汇率提供方,直接点new然后选一个就好了。

建好汇率提供方之后我们就可以导入汇率了。

配置一下各项参数。

我们可以配置一个批处理,让系统每隔一段时间自动重新导入一遍汇率信息。

然后我们可以在Currency exchange rates这个表中查看我们导入的汇率。

导入汇率后如何使用汇率呢。

我们可以在表中选择指定的币种,然后调用CurrencyExchangeHelper类的calculateCurrencyToCurrency方法,通过向该方法中传入我们在表中选择的币种,以及填写的“售价”字段来自动计算出根据所选汇率换算后的值,最后把这个换算后的值填到“单价”字段中。

我这里就是建了一个名为“币种”的枚举字段,当然我们也可以直接建个字符串字段然后关联Currency表的CurrencyCode字段。

接着我们重写一下表的modifiedField方法,实现当用户修改币种字段或售价字段的时候,系统调用calculateCurrencyToCurrency方法来自动根据汇率换算出单价字段的值。

public void modifiedField(FieldId _fieldId)
    {
        super(_fieldId);
          switch(_fieldId)
        {
            case fieldNum(TestTable, FromCurrency): // 如果编辑的是币种字段
                AmountMst amountMST; // AmountMst类需要导入Ledger model
                CurrencyCode FromCurrency =  enum2Str(this.FromCurrency);  // CurrencyCode类需要导入Currency model;enum2Str()方法能帮我们把枚举类型的值转成字符串类型
                CurrencyCode toCurrency =  'CNY';
                CurrencyExchangeHelper currencyExchangeHelper = CurrencyExchangeHelper::newExchangeDate(Ledger::current(), systemDateGet()); // 先建一个CurrencyExchangeHelper类的对象
                amountMST = currencyExchangeHelper.calculateCurrencyToCurrency(FromCurrency,toCurrency,this.SalesPrice,true); // 通过这个对象来调calculateCurrencyToCurrency()方法
                this.UnitPrice = amountMST; // 最后把换算后的值赋值给单价字段,注意AmountMst是Real类型的,所以单价字段也得是Real类型
                break;
            case fieldNum(TestTable, SalesPrice): // 如果编辑的是售价字段
                AmountMst amountMST2;
                CurrencyCode FromCurrency2 =  enum2Str(this.FromCurrency);
                CurrencyCode toCurrency2 =  'CNY';
                CurrencyExchangeHelper currencyExchangeHelper2 = CurrencyExchangeHelper::newExchangeDate(Ledger::current(), systemDateGet());
                amountMST2 = currencyExchangeHelper2.calculateCurrencyToCurrency(FromCurrency2,toCurrency2,this.SalesPrice,true);
                this.UnitPrice = amountMST2;
                break;
        }
      }

最后就可以实现自动根据所填金额和所选币种来换算金额了。

  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值