codewars--js--vowels counting+js正则相关知识
问题描述:
Return the number (count) of vowels in the given string.
We will consider a, e, i, o, and u as vowels for this Kata.
The input string will only consist of lower case letters and/or spaces.
function getCount(str) {
var vowelsCount = 0; // enter your majic here return vowelsCount;
}
我的答案:
function getCount(str) {
var vowelsCount = 0; // enter your majic here
var a=str.split("");
for (var i=0;i<a.length;i++){
if(a[i]=="a" || a[i]=="e" || a[i]=="i" || a[i]=="o" || a[i]=="u"){
vowelsCount+=1;
}
}
return vowelsCount;
}
对于本题,虽然想用string.match做,但是发现自己的正则不会,于是就选用了最原始的,逐个判断是不是元音。想哭!后来发现也有大神没有用match正则做,也可以。
优秀答案:
function getCount(str) {
let vowels = ['a','e','i','o','u'];
return str.split('').filter(letter => {
return vowels.includes(letter)? true : false;
}).length;
}
这是暂时排名第一的答案:(和我的想法一致,(#^.^#),但是我也写不成这么精简的一行)
function getCount(str) {
return (str.match(/[aeiou]/ig)||[]).length;
}
不过大神们,你们这样真的好吗?
补一波前面欠下的正则的债。
可用到正则的String方法 | 用法 |
match | match(regexp);返回符合规则的内容,格式为数组;失败为null |
search | search(regexp);返回符合规则的内容第一次出现的位置;失败为-1 |
replace | replace(regexp,newvalue);查找渡河正则的字符串,替换为newvalue;返回替换后的内容 |
以下总结参考
http://deerchao.net/tutorials/regex/regex.htm
http://www.jb51.net/article/110516.htm
- 元字符
元字符 含义 . 匹配除换行符之外的任意字符 \w 匹配字母或数字或下划线或汉字 \s 匹配任意的空白符space \d 匹配任意的数字digit \b 匹配单词的开始或结束 ^ 匹配字符串的开始 $ 匹配字符串的结束
- 元字符
- 转义字符
转义字符 含义 \. 对应字符 . \* 对应字符 * \\ 对应字符 \ - 重复
重复字符 含义 * 重复>=0 + 重复>=1 ? 重复0或1次 {n} 重复n次 {n,m} 重复n到m次,包含n和m {n,} 重复>=n - 字符类
匹配预设元素[ ] 含义 [aeiou] 匹配一个英文元音字母 [.!?] 匹配符号(. ! ?) [0-9] 匹配任意数字,同 \d [a-zA-Z0-9] 匹配任意数字字母,同 \w - 反义
元字符 含义 \W 匹配不是字母或数字或下划线或汉字的字符 \S 匹配任意不是空白符的字符 \D 匹配任意非数字的字符 \B 匹配不是单词的开始或结束的位置 [^x] 匹配除了x以外的字符串 [^aeiou] 匹配除aeiou以外的任意字符 - 修饰符
修饰符 含义 g 全局匹配 i 不区分大小 m 多行模式,会改变^ $行为 - JS创建正则
(1)var exp=/ pattern / flags; //其中pattern是正则表达式,flags是修饰符
例: var p=/ \b[aeiou][a-z]+\b/gi /;(2)var pattern= new RegExp("\\b[aeiou][a-z]+\\b","gi");
- JS匹配提取exec()
var matches=pattern.exec(str); //返回:结果数组或null
结果数组有两个属性,index表示匹配项所在字符串的位置; input表示源字符串
matches[0]表示匹配整个正则的第一个捕获的匹配的字符串;;;matches[n] 表示匹配整个正则的第n个捕获的匹配的字符串例如: var pattern=/ \b([a-zA-Z]+)ing\b /g;
var str="reading and writing";
则matches=pattern.exec(str); // matches.index为0时,matches[0]: reading matches[1]: read
// matches.index为12时,matches[0]: writing matches[1]: writ - JS匹配成功与否test()
var result=pattern.test(str); //返回:找到匹配项,返回true,否则false - 应用正则和思路
凡是和“找”有关的。而且是字符串的
两类应用正则问题
(1)验证类问题
(2)搜索、提取、替换类问题
codewars--js--vowels counting+js正则相关知识的更多相关文章
- js中错误处理的相关知识
错误bug是指程序执行过程中,导致程序无法正常执行的情况. 后果:程序会强行中断退出: 错误处理: 即使程序出现错误,也保证程序不异常中断的机制. 一般的使用的代 ...
- js中字符串和正则相关的方法
正则表达式对象常用方法 test() 检索字符串中指定的值.返回 true 或 false. var str="Embrace You" var r1=/you/i.test(st ...
- JS作用域相关知识(#精)
在学习<你不知道的JS>一书中,特将作用域相关知识在此分享一下: #说到作用域,就不得不提到LHS查询和RHS查询: 1)如果查询目的是对变量进行赋值,则使用LHS查询 2)如果查询目的是 ...
- [小问题笔记(六)] 解决JS已执行,输出内容乱码问题. 顺带总结编码相关知识
问题: JS输出的内容出现了乱码.如图: 分析:既然年和月的数字可以正常显示,证明js加载和执行都没有问题 解决:把js引用处的编码方式改成当前页面编码一致.charset="gb2312& ...
- Vue.js 相关知识(动画)
1. 简介 Vue 在插入.更新或移除 DOM 时,提供多种不同方式的过渡效果,并提供 transition 组件来实现动画效果(用 transition 组件将需执行过渡效果的元素包裹) 语法:&l ...
- js 面试题正则相关
正则相关[i不区分大小写,g匹配全部数据] var str = "Hello word! I think word is good."; 1.替换str中的word为javascr ...
- Dynamic CRM 2013学习笔记(二十三)CRM JS智能提示(CRM 相关的方法、属性以及页面字段),及发布前调试
我们知道在CRM的js文件里引用XrmPageTemplate.js后,就可以实现智能提示,但每个js文件都引用太麻烦了,其实可以利用vs的功能让每个js文件自动实现智能提示CRM的js: 另外,我们 ...
- js和HTML结合(补充知识:如何防止文件缓存的js代码)
来自<javascript高级程序设计 第三版:作者Nicholas C. Zakas>的学习笔记(二) 使用html标签<script>可以把js嵌入到html页面中,让脚本 ...
- JS -- 一篇文章掌握RequireJS常用知识
本文采取循序渐进的方式,从理论到实践,从RequireJS官方API文档中,总结出在使用RequireJS过程中最常用的一些用法,并对文档中不够清晰具体的内容,加以例证和分析,分享给大家供大家参考,具 ...
随机推荐
- matplotlib 散点图
一.特点 离散的数据,查看分布规律,走向趋势 二.使用 1.核心 plt.scatter(x, y) # x为x轴的数据,可迭代对象,必须是数字 # y为y轴的数据,可迭代对象,必须是数字 # x和y ...
- python算法学习总结
数据结构一维: 基础:数组array(string),链表Linked List 高级:栈stack,队列queue,双端队列deque,集合set,映射map(hash or map), etc二维 ...
- 定时任务莫名停止,Spring 定时任务存在 Bug??
Hello~各位读者新年好!这里楼下小黑哥给大家拜个年,祝大家蒸蒸日上烫烫烫,年年有余屯屯屯. 那年那 Bug 春节放假,小黑哥坐上高铁回家,突然想到一次生产问题.那是小黑哥参加工作第一年,那一年国庆 ...
- 剑指Offer对答如流系列 - 重建二叉树
面试题6:重建二叉树 题目描述: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树.假设输入的前序遍历和中序遍历的结果中都不含重复的数字.例如输入前序遍历序列{1,2,4,7,3,5,6,8} ...
- [ZJOI2008]树的统计(树链剖分)
[ZJOI2008]树的统计(luogu) Description 一棵树上有 n 个节点,编号分别为 1 到 n,每个节点都有一个权值 w.我们将以下面的形式来要求你对这棵树完成一些操作: I. C ...
- BERT模型总结
BERT模型总结 前言 BERT是在Google论文<BERT: Pre-training of Deep Bidirectional Transformers for Language U ...
- CTF--HTTP服务--路径遍历(拿到www-data用户权限)
开门见山 1. 扫描靶机ip,发现PCS 172.18.4.20 2. 用nmap扫描靶机开放服务及版本 3. 再扫描靶机的全部信息 4. 用nikto工具探测http服务敏感信息 5. 用dirb工 ...
- Git详解之内部原理
前言 不管你是从前面的章节直接跳到了本章,还是读完了其余各章一直到这,你都将在本章见识 Git 的内部工作原理和实现方式.我个人发现学习这些内容对于理解 Git 的用处和强大是非常重要的,不过也有人认 ...
- Oracle 数据泵(IMPDP/EXPDP)导入导出总结
Oracle数据泵导入导出是日常工作中常用的基本技术之一,它相对传统的逻辑导入导出要高效,这种特性更适合数据库对象数量巨大的情形,因为我日常运维的数据库对象少则几千,多则几万甚至几十万,所以传统exp ...
- Visual Studio Code | 报错 command 'markdown.extension.onBackspaceKey' not found
背景 今天使用Visual Strudio Code想用键盘Back去删除一些字符,发现报如下错误: command 'markdown.extension.onBackspaceKey' not f ...