バイナリ ->ASCII変換
このFP命令は、s2_BinaryDataで指定したエリアに格納されている16ビット/32ビットのバイナリデータをASCIIコードに変換します。変換方法は、s1_Formatの制御文字列で指定します。変換結果は、d_AsciiDataで指定したエリアに格納されます。
入力
引用符にセットされた制御文字列およびフォーマット文字列
バイナリデータを格納するための先頭アドレス
変換するデータの数: 0~65535
ASCIIデータの開始位置: 0~255
出力
ASCIIデータを格納するための先頭アドレス
制御コード内の位置 |
説明 |
s1_Format |
16ビットPLC |
32ビットPLC |
|
---|---|---|---|---|---|
変換方向 |
|||||
+ |
正方向(16進数で指定子xまたはXが指定されている場合のみ) |
'+%4X' |
● |
● |
|
+符号が省略されている場合:逆方向(デフォルト設定) |
'%4X' |
● |
● |
||
% |
フォーマット文字列指定子(必須) |
● |
● |
||
パディングフォーマット |
|||||
0 |
ゼロ埋め |
'%06x' |
- |
● |
|
+ |
+符号を付加 |
'%+4d' |
- |
● |
|
- |
左揃え |
'%-6d' |
- |
● |
|
˽ |
(スペース)プラス記号の代わりにスペースを追加 |
'%˽4d' |
- |
● |
|
# |
16進数に0xを挿入 |
'%#4X' |
- |
● |
|
実数には必ず小数点を付加 |
'%#8.0f' |
- |
● |
||
8 |
ASCIIデータ要素の長さ |
'%08d' |
● |
● |
|
文字長なし
|
'%d,' |
- |
● |
||
小数点以下の精度 |
|||||
.5 |
任意の小数点以下の桁数 |
'%8.5f' |
- |
● |
|
I |
倍長指定子 例: 指定子l付きi = Ii -> DINT |
'+%4ld' |
● |
● |
|
フォーマット指定子 |
|||||
i |
INT |
'%10i' |
● |
● |
|
u |
UINT |
'%10u' |
- |
● |
|
d |
INT |
'%6d' |
● |
● |
|
x |
16進数小文字 |
'+%4x' |
● |
● |
|
X |
16進数大文字 |
'+%4X' |
● |
● |
|
b |
BCD |
'+%5b' |
- |
● |
|
f |
浮動小数点数 |
'+%-6.2f' |
- |
● |
|
e |
指数1.23e10 |
'+%9.3e' |
- |
● |
|
E |
指数大文字1.23E10 |
'+%9.3E' |
- |
● |
|
g |
浮動小数点型実数または指数 |
'+%12g' |
- |
● |
|
G |
浮動小数点または指数大文字 |
'+%9.3G' |
- |
● |
|
|
'+%8dPANA' |
- |
● |
● 16ビット/32ビットPLCで利用可能
例: '+%4X'
は、バイナリ値を4文字長で大文字の順方向の値に変換します(16ビット/32ビットPLCの場合)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
16#12A |
'˽12A' |
例: '%4X'
は、バイナリ値を4文字長で大文字の逆方向の値に変換します(16ビット/32ビットPLCの場合)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
16#B2A |
'˽B2A' |
例: '%06d'
は、バイナリ値を6文字長で先頭の3桁がゼロの10進数の値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
16#100 |
'000100' |
例: '%+4d'
は、バイナリ値を4文字長で+記号付き10進数の値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
100 |
'+100 ˽ ˽' |
例: '%-6d'
は、バイナリ値を6文字長で左揃えの値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
100 |
'100˽ ˽ ˽' |
例: '%˽4d'
は、バイナリ値を4文字長で先頭に1つのスペースを持つ値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
100 |
'˽100' |
例: '%#8.0f'
は、バイナリ値を、8文字長、浮動小数点数、先頭に4つのスペースがある値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
123.45678 |
'˽ ˽ ˽ ˽123.' |
例: '%8.3f'
は、バイナリ値を8文字長で小数点以下3桁の精度を持つ値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
123.45599 |
'˽123.456' |
例: '+%10u'
は、バイナリ値を、10文字長で先頭に7つのスペースがある、符号なし整数の値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
-100 |
'˽ ˽ ˽ ˽ ˽ ˽ ˽100' |
例: '%06d'
は、バイナリ値を、6文字長、先頭に3つのスペースを持つ値に変換します(16ビット/32ビットPLCの場合)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
100 |
'˽ ˽ ˽100' |
文字長の値に指定可能な範囲:
指定子d、ld、i、liの前: 1~15 |
指定子Xの前: 1~4 |
指定子lXの前: 1~8 |
長さの指定がない場合、カンマを付加。例:'%d,'
(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
100 |
'100,' |
FP_BIN_TO_ASCII:必要最小限の長さを適用
FP_ASCII_TO_BINおよびFP_ASCII_CHECK: カンマ区切りが必要
例: '+%4ld'
は、バイナリ値を4文字長の値に変換します。変換結果にはDINTまたはDWORDが必要です(16ビット/32ビットPLCの場合)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
100 |
'˽100' |
例: '+%6i'
は、バイナリ値を6文字長で先頭に3つのスペースがある、符号付き整数の順方向の値に変換します(16ビット/32ビットPLCの場合)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
-100 |
'˽ ˽ ˽-100' |
例: '+%6d'
は、バイナリ値を6文字長で先頭に3つのゼロがある順方向の値に変換します(16ビット/32ビットPLCの場合)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
100 |
'000100' |
例: '+%4X'
は、バイナリ値を4文字長で大文字の16進数、順方向の値に変換します(16ビット/32ビットPLCの場合)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
16#12A |
'˽12A' |
例: '+%5b'
は、バイナリ値を5文字長のBCDデータの値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
16#123 |
'˽123' |
例: '+%-6.2f'
は、バイナリ値を6文字長で小数点以下2桁の精度を持つ、左揃えの値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
1.2345 |
'1.23˽' |
例: '+%9.3e'
は、バイナリ値を9文字長で小数点以下3桁の精度を持つ、小文字の指数表記の値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
1234.5678 |
'1.235e+03' |
例: '1.235E+03'
は、バイナリ値を9文字長で小数点以下3桁の精度を持つ、大文字の指数表記の値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
1234.5678 |
'1.235E+03' |
例: '+%12g'
は、バイナリ値を12文字長で浮動小数点数を持つ値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
1234.5678 |
'˽ ˽ ˽ ˽ ˽1234.57' |
例: '+%9.3G'
は、バイナリ値を9文字長で小数点以下3桁の精度の、浮動小数点数で大文字の指数表記に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
1234 |
'˽ ˽ ˽1.E+03' |
FP_BIN_TO_ASCIIの場合:変換に任意の文字列を付加することが可能
例: '+%8dPANA'
は、バイナリ値を8文字長で10進数の、'PANA'を追加した値に変換します(32ビットPLCの場合のみ)
バイナリデータ |
ASCIIデータの変換結果 |
---|---|
100 |
'˽ ˽ ˽ ˽ ˽100PANA' |
sFormatで指定した制御文字列に異常がある場合
sFormatで指定した変換フォーマットが10進数のときに、変換方向を順方向 (+) とした場合
s1_Formatで指定した変換フォーマットが16進数のときに、n_Conversionsで指定したASCIIコード格納エリアの大きさが規定値を超える場合(16ビットの場合の規定値: 4、32ビットの場合の規定値: 8)
n_Conversionsで指定した変換データ数が0の場合
変換結果がn_Conversionsで指定したASCIIコード格納エリアの大きさを超える場合
変換結果がエリアを超える場合
sFormatで指定した制御文字列に異常がある場合
sFormatで指定した変換フォーマットが10進数のときに、変換方向を順方向 (+) とした場合
s1_Formatで指定した変換フォーマットが16進数のときに、n_Conversionsで指定したASCIIコード格納エリアの大きさが規定値を超える場合(16ビットの場合の規定値: 4、32ビットの場合の規定値: 8)
n_Conversionsで指定した変換データ数が0の場合
変換結果がn_Conversionsで指定したASCIIコード格納エリアの大きさを超える場合
変換結果がエリアを超える場合
POUヘッダには、このプログラムで使用するすべての入力変数と出力変数を宣言します。 POUヘッダは全プログラム言語で使用できます。
VAR
bStart: BOOL:=FALSE;
iArray1: ARRAY [0..1] OF INT:=[1234,-56];
iAscii1: ARRAY [0..4] OF WORD:=[5(16#FFFF)];
END_VAR
変数bStartがFALSEからTRUEに変化すると、このファンクションが実行されます。2つの16ビットバイナリデータを"2 x 4"の10進アスキーデータに変換します。オフセット=ASCII 1文字(8ビット)
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 10 ;
NETWORK_BODY
B(B_VARIN,,'%4d',10,5,12,7,);
B(B_VARIN,,iArray1,10,6,12,8,);
B(B_VARIN,,2,10,7,12,9,);
B(B_VAROUT,,iAscii1,25,5,27,7,);
B(B_CONTACT,,bStart,7,4,9,6,R);
B(B_COMMENT,,Converts two 16-bit units to 2x4 decimal ASCII data. Offset = 1 ASCII character (8-bit).,5,1,38,3,);
B(B_F,FP_BIN_TO_ASCII!,,12,3,25,10,,?DEN?hs1_Format?ds2_BinaryData?dn_Conversions?dn_AsciiDataStartPosition?AENO?cd_AsciiData);
B(B_VARIN,,1,10,8,12,10,);
B(B_COMMENT,,Result iAscii1: 'x1234 -56x',28,8,41,9,);
L(9,5,12,5);
L(1,5,7,5);
L(1,0,1,10);
END_NETWORK_BODY
END_NET_WORK
END_BODY
IF DF(bStart) then
FP_BIN_TO_ASCII(s1_Format := '%4d',
s2_BinaryData := iArray1,
n_Conversions := 2,
d_AsciiData => iAscii1);
END_IF;