2005 Jan 04 3:24 PM
Guys:
This is might be not SAP related!!!
What is Ascii charter for 23 in Microsoft Excel since i am sending excel sheet to uploading data into SAP. SAP standard program spliting data based on the 23 Ascii value so i will also separate my excel file by 23 Ascii char.
Thanks in advance
Suresh Babu Karanam
2005 Jan 04 3:38 PM
Hi Suresh,
ASCII 23 = ETB (Hex = 17) (Char = ^W)
Meaning = End transmission block, not the same as EOT
You might take a look at site:
http://www.robelle.com/library/smugbook/ascii.html
Regards,
Rob.
2005 Jan 06 8:49 AM
Guys:
My requirment is i have one,two and three variables. i need to concatenate and <b>separeted char 23 is ASCII value</b>.
one = my.
two = sap.
CONCATENATE one two INTO three
<b>SEPARATED BY (ASCII 23)</b>
How can i go about that above issue. If any body have idea please share with me.
Advanced Thanks
Suresh Babu Karanam
2005 Jan 06 1:40 PM
Hi Suresh,
there is a work-around with structures:
DATA: BEGIN OF ascii23_struc,
field TYPE x,
END OF ascii23_struc,
ascii23 TYPE char1.
ascii23_struc-field = 23.
MOVE ascii23_struc TO ascii23.
Unfortunately it's not longer supported with unicode.
I didn't find 23 somewhere in SAP, but for some other characters following is available (in 4.7):
ascii23 = cl_abap_char_utilities=>horizontal_tab.
In older version an include or type-pool for some general definitions should be available.
Regards,
Christian
2005 Jan 06 2:42 PM
Hi Suresh,
You can easily concatenate using a ASCII value and also split the concatenated string at ASCII value.
Check the below code,
DATA: temp_hexa TYPE x VALUE 23,
one(10) TYPE c,
two(10) TYPE c,
three(20) TYPE c,
i_itab TYPE TABLE OF string,
w_itab like line of i_itab.
one = 'My'.
two = 'SAP'.
Concatenation of the strings using ascii 23
CONCATENATE one temp_hexa two INTO three.
WRITE:/ 'one :',one,' two :',two.
WRITE:/'three :',three.
Slpitting the strings at ascii 23
SPLIT three AT temp_hexa INTO TABLE i_itab.
LOOP AT i_itab into w_itab.
WRITE:/ w_itab.
ENDLOOP.
But when the concatenated string is print it will show the ASCII as # (i don't know why).
Hope that is helpful to you.
Regards,
Kathirvel.
2005 Jan 06 2:52 PM
Interesting you say that,
<i>
But when the concatenated string is print it will show the ASCII as # (i don't know why). </i>
data : temp_hexa TYPE x VALUE 23
temp_hexa has a hexadecimal type. So the value assigned would be hexadecimal and therefore 23 would actually be 3 + 16 * 2 = 35 and ASCII for 35 is #
So you should use value as 17.
Regards,
Subramanian V.
P.S. - Nevertheless it is a novel way
Message was edited by: Subramanian Venkateswaran
2005 Jan 06 3:02 PM
Hi Subu,
You assign any ascii value to a hexa decimal type variable (say the temp_hexa), and print it on a list, i tried '09' for tab, '44' for ,(comma), but in the list it was only #.
If you could really solve this out for me it will be really nice.
Please try this and tell me the results.
Thanks in advance.
Kathirvel.
2005 Jan 06 3:56 PM
Christian:
Thank you very much for usefull information. If po'ble 09 ASCII value charecter will also solve my purpose.
Regards
Suresh Babu Karanam
2005 Jan 06 4:03 PM
Hi Suresh,
If you got some answers please share them, it will be help for us.
Regards,
Kathirvel.
2005 Jan 06 4:32 PM
Hi Guys:
please test the following code in the debugging mode you can identify for <b>same char(#)</b> have different <b>hexa decimal</b> values.
code
-
data : gd_separator type c.
data : test type c value '#'.
gd_separator = cl_abap_char_utilities=>horizontal_tab.
Once again thanks for all your help.
Regards
Suresh Babu Karanam
2005 Jan 06 5:04 PM
Hi,
some more comments:
data temp type x value 23 "23 is entered as decimal, so this was correct (not 17)
When printing or debugging, we are all using SAP's list processor - and there are some restrictions to "printable characters": that's why most times just # as replacement is displayed. This doesn't occur in file download, but would be visible by using AL11 for displaying the file - just use a local editor for checking (the existence of tabulator for example).
If tabbed file is enough, two ways are handy: using a structure
TYPES: BEGIN OF types_line,
one TYPE mara-matnr,
sep01 TYPE c,
three TYPE kna1-kunnr,
sep02 TYPE c,
...
end of types_line.
...
start-of-selection.
CLASS cl_abap_char_utilities DEFINITION LOAD.
wa_line-sep01 = cl_abap_char_utilities=>horizontal_tab.
*( or old-style like mentioned above)
MOVE wa_line-sep01 TO: wa_line-sep02, ...
...
Or you use concatenate ... separated by sep...
which will lead to different results, when your fields contain spaces - shouldn't bother with Excel.
Regards,
Christian
2005 Jan 07 3:36 AM
Thanks Christian for sharing that piece of information.
Just to confirm your statement, I wrote this piece of code, and the difference is in the quotes. Something new to learn every day, I guess.
data: hexa1 type x value '23'.
data: hexa2 type x value 23.
data: character type c.
if hexa1 eq hexa2.
write 'Equals'.
else.
write 'Does not equal'.
endif.
And hexcode 23 translating to 35 in decimal and exactly matching with the '#' code is just too much of a coincidence , I guess, for my theory.
Thanks again.
Regards,
Subramanian V.
2005 Jan 07 3:22 AM
Thanks Suresh and Christian,
I have something more to add, some time back i got stuck in a same kind of problem; i found some results, they are
1. If we want to use some separators mainly ASCII, they must be declared as hexa decimal values in most cases.
2. The above is much applicable when we want to split a string that has been concatenated using an ASCII value.
3. When such a string is concatenated and printed it will not display most of the ASCII values like (TAB - 09, ETB - 23, etc) instead it will display a # value only (but the hexa value will correspond to the actual ASCII value if debugged).
4. But when the same concatenated value is downloaded into a file the assigned ASCII value can be found.
Thus like Christian told these may be due to restrictions to "Printable Characters".
Once again Thanks to you all,
Regards,
Kathirvel.
2005 Jan 09 4:49 PM
Christian Thanks for you information i got solution to my probelm. Since 4 days i trying to figure out .
Regards
Suresh Babu Karanam