Прописная / заглавная первая буква каждого слова в строке в Matlab?


Как лучше всего прописать / прописать первую букву каждого слова в строке в Matlab?

То есть.
дождь в Испании падает в основном на самолет
чтобы
дождь в Испании падает в основном на самолет

4 7

4 ответа:

Итак, используя строку

str='the rain in spain falls mainly on the plain.'

Просто используйте функцию замены regexp в Matlab, regexprep

regexprep(str,'(\<[a-z])','${upper($1)}')

ans =

The Rain In Spain Falls Mainly On The Plain.

\<[a-z] соответствует первому символу каждого слова, которое можно преобразовать в верхний регистр с помощью ${upper($1)}

Это также будет работать с использованием \<\w, чтобы соответствовать символу в начале каждого слова.

regexprep(str,'(\<\w)','${upper($1)}')

Поскольку Matlab поставляется сbuild in Perl , для каждой сложной задачи обработки строк или файлов можно использовать Perl-скрипты. Так что вы могли бы использовать что-то вроде этого:

[result, status] = perl('capitalize.pl','the rain in Spain falls mainly on the plane')

Где capitalize.pl является скриптом Perl следующим образом:

$input  = $ARGV[0];
$input =~ s/([\w']+)/\u\L$1/g;
print $input;

Код perl был взят изэтого вопроса о переполнении стека .

Множество способов:

str = 'the rain in Spain falls mainly on the plane'

spaceInd = strfind(str, ' '); % assume a word is preceded by a space
startWordInd = spaceInd+1;  % words start 1 char after a space
startWordInd = [1, startWordInd]; % manually add the first word
capsStr = upper(str);

newStr = str;
newStr(startWordInd) = capsStr(startWordInd)

Более элегантный / сложный -- Cell-массивы, textscan и cellfun очень полезны для такого рода вещей:

str = 'the rain in Spain falls mainly on the plane'

function newStr = capitals(str)

    words = textscan(str,'%s','delimiter',' '); % assume a word is preceded by a space
    words = words{1};

    newWords = cellfun(@my_fun_that_capitalizes, words, 'UniformOutput', false);
    newStr = [newWords{:}];

        function wOut = my_fun_that_capitalizes(wIn)
            wOut = [wIn ' ']; % add the space back that we used to split upon
            if numel(wIn)>1
                wOut(1) = upper(wIn(1));
            end
        end
end
    str='the rain in spain falls mainly on the plain.' ;
for i=1:length(str)
    if str(i)>='a' && str(i)<='z'
        if i==1 || str(i-1)==' '
            str(i)=char(str(i)-32); % 32 is the ascii distance between uppercase letters and its lowercase equivalents
        end
    end
end
Менее эллегантный и эффективный, более читаемый и ремонтопригодный.