查找字符串中第一个最长的单词,不包括符号

Find first longest word in a string, excluding symbols

本文关键字:单词 不包括 符号 字符串 第一个 查找      更新时间:2023-09-26
function longestWord(string) {
    var str = string.split(" ");
    var longest = 0;
    var word = null;
    for (var i = 0; i < str.length; i++) {
        var checkedLetters = "";
        for (var j = 0; j < str[j].length; j++) {
            if (j == /[^a-zA-Z]/) {
                checkedLetters += j;
            }
        if (longest < checkedLetters.length) {
            longest = checkedLetters.length;
            word = checkedLetters;
           }
        }
    }
    return word;
}

我使用正则表达式有什么问题吗?当我调用longestWord("Hello,我在这里"(时,我希望它返回"Hello"(不带逗号(,但它返回null。

刚刚写了这个小片段,可能会帮助你:

function longestWord(string){
    return string.match(/[a-zA-Z]+/g)
               .reduce(function(a,b){
                    return a.length>=b.length?a:b;
               })
}

/[a-zA-Z]+/g匹配字符串中的所有单词,并返回它们的数组。上面的测试字符串("Hello, I am here"(将变为["Hello","I","am","here"]当这个正则表达式运行时。

一旦我有了这个数组,只需循环遍历它以找到最长的单词即可。我通过使用.reduce

.

你的代码中有一些错误:

for (var j = 0; j < str[j].length; j++) {

应该是

 for (var j = 0; j < str[i].length; j++) {

if (j == /[^a-zA-Z]/) {

应该是:

if (/[a-zA-Z]/.test(str[i][j])) {

您的最终代码应该是:

function longestWord(string) {
    var str = string.split(" ");
    var longest = 0;
    var word = null;
    for (var i = 0; i < str.length; i++) {
        var checkedLetters = "";
        for (var j = 0; j < str[i].length; j++) {
            if (/[a-zA-Z]/.test(str[i][j])) {
                checkedLetters += str[i][j];
            }
        }
        if (longest < checkedLetters.length) {
            longest = checkedLetters.length;
            word = checkedLetters;
        }
    }
    return word;
}

查看演示

使用正则表达式的方式的最大(非拼写错误(问题是该方法.test ; ==将测试字符串是否等于正则表达式的字符串表示形式。

只需使用.match和一点点sort魔法!

function longestWord(string){
    var words = string.match(/'w+/g);
    words.sort(function(a, b) { return b.length - a.length; });
    // Firefox 22.0 promotion:
    // words.sort((a, b) => a.length - b.length);
    return words[0];
}
你不需要

使用正则表达式,你可以使用 .length 来搜索最长的字符串。

function longestWord(string) {
    var str = string.replace(/['.,-'/#!$%'^&'*;:{}='-_`~()]/g,"").split(" ");
    longest = str[0].length;
    longestWord = str[0];
    for (var i = 1; i < str.length; i++) {
        if (longest < str[i].length) {
            longest = str[i].length;
            longestWord= str[i];
           }
        }
return longestWord;
}

编辑:你必须使用一些正则表达式...