How could i search a text for varying patterns
조회 수: 1 (최근 30일)
이전 댓글 표시
Hello, I am trying to search through an excel file looking through model names and only pulling out the option codes.
For Example the excel sheet with the model names would look like: '1010AB-50K-TB' '1010AB-25K-B' '1010AB-100K'
and I want to create a new array with just the option codes (which in this case is AB). So to look something like this:
'AB' 'AB' 'AB'
and so on... the option codes vary from two letters to three letters and vary from A-Z (AB, AE, AF, AAA, ABD). The only consistency in the model names is the four numbers before the option code and the dash after. How do y'all think the best way to do this would be?
댓글 수: 4
Paolo
2018년 5월 23일
I have edited my regex expression, now the first letter will also range from A to Z. Check out my answer down below.
채택된 답변
Paolo
2018년 5월 23일
편집: Paolo
2018년 5월 23일
For a pattern of two to three letters, starting with any letter (A to Z) and ending with any letter (A to Z) you can use the following code:
expression = '([A-Z][A-Z]?[A-Z](?=-))';
model_names = {'A1010ACZ-50K-AAA' '1010AB-25K-B' '1010AT-100K'};
[tokens] = regexp(cell2mat(model_names),expression,'tokens');
The expression has three elements, all ranging from A to Z (the [A-Z]). The third element is optional (denoted by the question mark). The expression contains a lookahead (?=-) which searches for the dash however does not include it in the tokens.
The code returns:
tokens{:} = {'ACZ'},{'AB'},{'AT'}
댓글 수: 5
Paolo
2018년 5월 23일
Are you working with each model number individually? If so, you can either use:
expression = '([A-Z][A-Z]?[A-Z](?=-)).*'
or even specify once in the function:
[tokens] = regexp(model_names,expression,'tokens','once');
Or are you working with a cell array?
추가 답변 (1개)
jonas
2018년 5월 23일
편집: jonas
2018년 5월 23일
Not sure if it's the best way, but the code starts at str(5) and ends at the dash, so this should work
[~,s] = regexp(str, '-', 'match')
out=str(5:s(1)-1)
댓글 수: 2
Paolo
2018년 5월 23일
Unsure as to why you selected this answer. The code is limited in application and will not work if for some reason the codes change format, let's say from
1010AB-50K-TB
to
10105AB-50K-TB
will result in an incorrect output.
5AB
참고 항목
카테고리
Help Center 및 File Exchange에서 Characters and Strings에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!