|
|
|
|
|
- What is UNICODE
- Managing UNICODE
- Implicit conversions
Unicode in character strings
UNICODE is an encoding system that assigns a unique number to each character: - This system uses a 16-bit encoding.
- This number can be read regardless of the platform, software or language used.
Unicode supports most of the world's writing systems. Unicode is used: - for character strings
- for data files
- for controls that display data from character strings or data files.
To use the UNICODE standard, WINDEV includes: - an option to define the string format at runtime in the project configuration description.
To change the string format in the current configuration:
- Display the project description window: under the "Project" pane, in the "Project configuration" group, click on "Current configuration"..
- In the window that appears, select the "Unicode" tab and choose the desired mode: "Use ANSI strings at runtime" or "Use UNICODE strings at runtime".
- the UNICODE String type.
- conversion functions:
These functions convert ANSI characters to Unicode and vice versa. Character strings are automatically converted (see paragraph below).
| | AnsiToUnicode | Converts:- an ANSI string (Windows) to a UNICODE string.
- a buffer containing an ANSI string (Windows) to a buffer containing a UNICODE string.
| StringToUTF8 | Converts an ANSI or UNICODE string to UTF-8. | UnicodeToAnsi | Converts:- a UNICODE string to ANSI (Windows).
- a buffer containing a UNICODE string to a buffer containing an ANSI string (Windows).
| UTF8ToString | Converts a UTF-8 string to ANSI or UNICODE. |
- functions to handle character strings:
| | Complete | Returns a character string of a specified length. | CompleteDir | Adds a backslash to the end of a string, if necessary. | ExtractString | Allows you to:- extract a substring from a string based on a specified string separator.
- search for substrings in a string based on a specified string separator.
| Left | Extracts the left part (i.e., the first characters) from a string or buffer. | Length | Returns:- the length of a string, i.e., the number of characters in the string (including spaces and binary zeros).
- the size of a buffer, i.e., the number of bytes in the buffer.
| Middle | Extracts: - a substring from a string starting at a specified position.
- part of a buffer starting at a specified position.
| NoAccent | Converts accented characters in a string to non-accented characters. | NoSpace | Returns a string after removing the spaces: - from the left and right side of the initial string.
- within the string.
| Position | Finds the position of a specified string within another string. | PositionOccurrence | Finds the Xth position of a string within another string. | RepeatString | Concatenates N number of copies of the same specified string or buffer. | Replace | Replaces all occurrences of a specified substring in a string with another specified substring. | Reverse | Returns the character that corresponds to the difference between the ASCII code of a specific character in a string and 255. | Right | Extracts the last characters from a string or string buffer. | StringCompare | Compares two strings character by character:- according to the sequence of ASCII characters.
- according to the alphabetical order.
| StringCount | Calculates: - the number of occurrences of a specific character string (by respecting the search criteria) in another character string.
- the number of occurrences of a set of strings in an array.
| StringFormat | Formats a character string according to the selected options. | TypeVar | Identifies the type of an expression, a variable (during a call to a procedure for example) or a control. | Val | Returns the numeric value of a character string. |
- the use of operators for handling character strings:
- operators to iterate over character strings:
- the use of functions for handling text files:
| | fOpen | Opens an external file (ANSI or Unicode) to handle it programmatically. | fRead | Reads a block of bytes (characters) from an external file (ANSI or UNICODE). | fReadLine | Reads a line from an external file (ANSI or UNICODE). | fWrite | Writes a string to an external file (ANSI or UNICODE). | fWriteLine | Writes a line to a text file (ANSI or UNICODE). |
Implicit conversions Starting with version 12, ANSI and Unicode strings are automatically converted. These conversions are performed using the current character set (defined with ChangeCharset). From version 15 onwards, UNICODE character strings are automatically converted when assigning one of the following types to an HFSQL field: Boolean, integer (all sizes, with or without sign), monetary, numeric or real. Use cases:
ResU is string Unicode = AnsiVersUnicode("Test d'une chaîne")
ResU is string Unicode = "Test d'une chaîne"
Res is string
ResU is string Unicode
ResU = AnsiToUnicode(Res)
Res = UnicodeToAnsi(ResU)
ResU = Res
Res = ResU
Res is string
ResU is string Unicode
IF ResU <> AnsiToUnicode("") THEN ...
IF ResU <> AnsiToUnicode(Res) THEN ...
IF ResU <> "" THEN ...
IF ResU <> Res THEN ...
nFic is int = fOuvre("E:\temp\Unicode.txt", foRead + foUnicode)
ResU is string Unicode
ResU = fReadLine(nFic)
WHILE ResU <> EOT
Trace(ResU)
ResU = fReadLine(nFic)
END
This page is also available for…
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|