F-02手工记账(凭证货币JPY)报错,消息号00011“小数位不允许”(Decimal places are not permitted)-OY04和金额内外部转换函数

本文介绍了在SAP中手工记账和自动生成会计凭证时遇到的小数位错误,如00011和RW033。问题源于SAP对特定货币小数位的预设限制,例如JPY不允许小数。解决方案包括在OY04中调整货币配置或对已有数据进行处理。同时,文章提到了金额内外部转换函数BAPI_CURRENCY_CONV_TO_EXTERNAL及其转换因子的计算方法。
摘要由CSDN通过智能技术生成

一、场景概述

SAP常用会计凭证生成方式:手工记账和通过BAPI自动创建。

针对一些小额度币种,可能会出现如下的报错:
手工帐:消息号00011“小数位不允许”(Decimal places are not permitted)
自动账:消息号RW033“会计接口:以交易货币1 (JPY) ”

示例:
凭证货币:JPY
公司代码本位币:HKD

1.1 手工记账F-02

消息号00011“小数位不允许”(Decimal places are not permitted)
在这里插入图片描述

1.2 自动生成凭证

自开发生成凭证或者其他模块和FI集成自动产生凭证等场景。

消息号RW033“会计接口:以交易货币1 (JPY) ”
在这里插入图片描述

二、原因分析-OY04

SAP预设了一些币种的允许的小数位。
T-CODE: OY04
对应后台表:TCURX
在这里插入图片描述
JPY不允许有小数位
KWD允许有3位小数

注意点1】配置表中没有的货币,表示允许2位小数点
注意点2】变更配置表中货币的小数位,会导致该货币对应的历史数据的放大或缩小

2.1 实际场景原因分析

F-02创建会计凭证报错的消息很清晰了,不再赘述。重点解析自动生成凭证。

自动生成凭证时,系统会自动根据凭证货币来对金额进行四舍五入处理。

以JPY为例。
金额:37063.64
因为JPY不允许有小数,系统实际金额是37064

这样处理的结果可能最终导致借贷金额不平。

出现报错消息:消息号RW033“会计接口:以交易货币1 (JPY) ”

【业务实践】
1、JPY没有发生过业务,直接在OY04中设置JPY允许保留的小数位数
2、如果已存在JPY的业务数据,则只能取整后续增强业务数据

三、金额内外部转换函数

函数:BAPI_CURRENCY_CONV_TO_EXTERNAL 根据货币把金额从内部转为外部

转换因子确定:
系统默认的位数2,默认转换因子为1。
JPY为0位小数,转换因子为100 实际金额存入值:实际金额 / 100 即缩小100倍
BHD为3位小数,转换因子为1/10 实际金额存入值:实际金额 / (1/10) 即扩大10倍

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是一个使用forex-python库实现货币转换的Python程序,程序会创建一个简单的GUI窗体,用户可以在窗体中输入要转换金额货币类型,然后选择要转换到的货币类型,程序会根据用户的选择计算并显示转换结果。 ```python import tkinter as tk from tkinter import ttk from forex_python.converter import CurrencyRates # 创建货币转换器对象 c = CurrencyRates() # 创建主窗口 root = tk.Tk() root.title('货币转换器') # 创建控件 amount_label = ttk.Label(root, text='金额:') amount_entry = ttk.Entry(root) from_currency_label = ttk.Label(root, text='从货币类型:') from_currency_combo = ttk.Combobox(root, values=['USD', 'EUR', 'JPY', 'GBP']) to_currency_label = ttk.Label(root, text='到货币类型:') to_currency_combo = ttk.Combobox(root, values=['USD', 'EUR', 'JPY', 'GBP']) convert_button = ttk.Button(root, text='转换') result_label = ttk.Label(root, text='转换结果:') result_value = ttk.Label(root, text='') # 控件布局 amount_label.grid(row=0, column=0, padx=5, pady=5, sticky='w') amount_entry.grid(row=0, column=1, padx=5, pady=5) from_currency_label.grid(row=1, column=0, padx=5, pady=5, sticky='w') from_currency_combo.grid(row=1, column=1, padx=5, pady=5) to_currency_label.grid(row=2, column=0, padx=5, pady=5, sticky='w') to_currency_combo.grid(row=2, column=1, padx=5, pady=5) convert_button.grid(row=3, column=0, columnspan=2, padx=5, pady=5) result_label.grid(row=4, column=0, padx=5, pady=5, sticky='w') result_value.grid(row=4, column=1, padx=5, pady=5) # 定义转换函数 def convert(): amount = float(amount_entry.get()) from_currency = from_currency_combo.get() to_currency = to_currency_combo.get() result = c.convert(from_currency, to_currency, amount) result_value.config(text=result) # 绑定事件 convert_button.config(command=convert) # 运行主循环 root.mainloop() ``` 程序使用了forex-python库来获取货币汇率,并创建了一个GUI窗口,用户可以在窗口中输入要转换金额货币类型,选择要转换到的货币类型,然后点击转换按钮进行转换。程序将用户输入的金额货币类型传递给forex-python库的`convert`函数,该函数会根据货币汇率计算出转换结果,并将结果显示在窗口中。 注意:在使用程序前,需要先安装forex-python库。可以使用以下命令在命令行中安装: ``` pip install forex-python ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王小磊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值