String Replacing for a DNA sequence

1 回表示 (過去 30 日間)
Reshma Ravi
Reshma Ravi 2017 年 6 月 2 日
コメント済み: Reshma Ravi 2017 年 6 月 2 日
I want to extract the row from a table whose count is greater than 1, where the first column consists of strings and second column its count. For eg, Table A = AAGC 1 GCCU 2 AGCU 2 CCGU 1 The desired output is : GCCU 2 AGCU 2
  2 件のコメント
Andrei Bobrov
Andrei Bobrov 2017 年 6 月 2 日
編集済み: Andrei Bobrov 2017 年 6 月 2 日
Please example with beginning sequence and with finished result.
Jan
Jan 2017 年 6 月 2 日
What are "repeated substring" exactly?

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

採用された回答

Andrei Bobrov
Andrei Bobrov 2017 年 6 月 2 日
編集済み: Andrei Bobrov 2017 年 6 月 2 日
A = {'AAGC', 1 ;'GCCU', 2 ;'AGCU', 2; 'CCGU' 1};
T = cell2table(A,'var',{'DNA','count'});
Tout = T(T.count > 1,:);
  1 件のコメント
Reshma Ravi
Reshma Ravi 2017 年 6 月 2 日
Thanks Sir.

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

その他の回答 (1 件)

Jan
Jan 2017 年 6 月 2 日
Imagine that you worked out how to get a cell string containing the sub-strings:
C = {'GTTA', 'TTAG', 'TAGC', 'GTTA', 'GTTA', 'GTTA', 'TTAG'};
Now find the repeated strings:
repeated = strcmp(C(1:end-1), C(2:end));
Unfortuinately the description is not clear:
if GTTA is repeated 4 times then replace it with another non terminal for example,
A or something like that.
Do you want to replace each repeated string by the character 'A', or all 4 repetitions by one 'A'? This might be:
C(repeated) = {'A'};
[B, N, Index] = RunLength(repeated);
As long as I'm not sure, what you are asking for, I will not spend more time in creating an explicite answer. But you can try it by your own.
  1 件のコメント
Reshma Ravi
Reshma Ravi 2017 年 6 月 2 日
Thanks Sir.

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

カテゴリ

Help Center および File ExchangeGenomics and Next Generation Sequencing についてさらに検索

タグ

Community Treasure Hunt

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

Start Hunting!

Translated by