It has been shown above that strings can be concatenated using matrix notation
(see Strings, Character Arrays). Apart from that, there are several
functions to concatenate string objects: char,
strvcat, strcat and cstrcat. In addition, the general
purpose concatenation functions can be used: see cat,
horzcat and vertcat.
cstrcat
convert numerical input into character data by taking the corresponding ASCII
character for each element, as in the following example:
char([98, 97, 110, 97, 110, 97])
⇒ ans =
banana
char and strvcat
concatenate vertically, while strcat and cstrcat concatenate
horizontally. For example:
char("an apple", "two pears")
⇒ ans =
an apple
two pears
strcat("oc", "tave", " is", " good", " for you")
⇒ ans =
octave is good for you
char generates an empty row in the output
for each empty string in the input. strvcat, on the other hand,
eliminates empty strings.
char("orange", "green", "", "red")
⇒ ans =
orange
green
red
strvcat("orange", "green", "", "red")
⇒ ans =
orange
green
red
cstrcat also accept cell
array data (see Cell Arrays). char and
strvcat convert cell arrays into character arrays, while strcat
concatenates within the cells of the cell arrays:
char({"red", "green", "", "blue"})
⇒ ans =
red
green
blue
strcat({"abc"; "ghi"}, {"def"; "jkl"})
⇒ ans =
{
[1,1] = abcdef
[2,1] = ghijkl
}
strcat removes trailing white space in the arguments (except
within cell arrays), while cstrcat leaves white space untouched. Both
kinds of behavior can be useful as can be seen in the examples:
strcat(["dir1";"directory2"], ["/";"/"], ["file1";"file2"])
⇒ ans =
dir1/file1
directory2/file2
cstrcat(["thirteen apples"; "a banana"], [" 5$";" 1$"])
⇒ ans =
thirteen apples 5$
a banana 1$
Note that in the above example for cstrcat, the white space originates
from the internal representation of the strings in a string array
(see Character Arrays).
Create a string array from one or more numeric matrices, character matrices, or cell arrays. Arguments are concatenated vertically. The returned values are padded with blanks as needed to make each row of the string array have the same length. Empty input strings are significant and will concatenated in the output.
For numerical input, each element is converted to the corresponding ASCII character. A range error results if an input is outside the ASCII range (0-255).
For cell arrays, each element is concatenated separately. Cell arrays converted through
charcan mostly be converted back withcellstr. For example:char ([97, 98, 99], "", {"98", "99", 100}, "str1", ["ha", "lf"]) ⇒ ["abc " " " "98 " "99 " "d " "str1 " "half "]
Create a character array from one or more numeric matrices, character matrices, or cell arrays. Arguments are concatenated vertically. The returned values are padded with blanks as needed to make each row of the string array have the same length. Unlike
char, empty strings are removed and will not appear in the output.For numerical input, each element is converted to the corresponding ASCII character. A range error results if an input is outside the ASCII range (0-255).
For cell arrays, each element is concatenated separately. Cell arrays converted through
strvcatcan mostly be converted back withcellstr. For example:strvcat ([97, 98, 99], "", {"98", "99", 100}, "str1", ["ha", "lf"]) ⇒ ["abc " "98 " "99 " "d " "str1 " "half "]
Return a string containing all the arguments concatenated horizontally. If the arguments are cells strings,
strcatreturns a cell string with the individual cells concatenated. For numerical input, each element is converted to the corresponding ASCII character. Trailing white space is eliminated. For example:s = [ "ab"; "cde" ]; strcat (s, s, s) ⇒ "ab ab ab " "cdecdecde"s = { "ab"; "cde" }; strcat (s, s, s) ⇒ { [1,1] = ababab [2,1] = cdecdecde }