Substitute and add rows to a cella rray

3 ビュー (過去 30 日間)
Francesca Danielli
Francesca Danielli 2022 年 1 月 4 日
回答済み: SANKALP DEV 2023 年 9 月 13 日
Hi everyone,
I have two cells of strings: A(a,1) and B(b,1), where a>b.
I want to add B in A at a certain position, where there are already c blank rows (c<b).
I tried it with "replace", obtaining the following error:
"Replacement text must be either scalar or the same size as the match text."
Any suggestion?
Thank you :)
  3 件のコメント
Francesca Danielli
Francesca Danielli 2022 年 1 月 5 日
the elements of B are not inserted in A because the code stops before
KSSV
KSSV 2022 年 1 月 5 日
It would be better if you show us a small example code with data.

サインインしてコメントする。

回答 (1 件)

SANKALP DEV
SANKALP DEV 2023 年 9 月 13 日
Hi Francesca,
I understand that you are currently facing a challenge involving the addition of a cell array 'B' into specific positions within 'A,' where there are existing 'C' blank rows.
The error message you've encountered suggests that the replacement text provided during the "replace" operation may not align in size with the matched text.
To address this error, a solution would involve splitting the cell array 'A' into two parts
  • The substring before the positions of the blank rows.
  • The substring after the positions of the blank rows.
Following this split, you can concatenate the string preceding the blank, the contents of cell array 'B,' and the string following the blank. Finally, assign this updated array back to 'A.'
I have assumed that you already know the index of the blank rows in 'A.' However, if you're uncertain about these indices, you can find them using the following code:
blank_positions = find(cellfun('isempty', A));
For more detailed information about the functions mentioned above, you can refer to the following documentations:
Hope this helps.

カテゴリ

Help Center および File ExchangeCharacters and Strings についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by