揭开JavaScript字符串搜索的秘密:indexOf、includes与KMP算法

本文涉及的产品
实时计算 Flink 版,1000CU*H 3个月
实时数仓Hologres,5000CU*H 100GB 3个月
智能开放搜索 OpenSearch行业算法版,1GB 20LCU 1个月
简介: JavaScript字符串搜索涵盖`indexOf`、`includes`及KMP算法。`indexOf`返回子字符串位置,`includes`检查是否包含子字符串。KMP是高效的搜索算法,尤其适合长模式匹配。示例展示了如何在数据采集(如网页爬虫)中使用这些方法,结合代理IP进行安全搜索。代码示例中,搜索百度新闻结果并检测是否含有特定字符串。学习这些技术能提升编程效率和性能。

亿牛云代理.png

在JavaScript编程中,字符串搜索是一个常见而基础的操作。无论是查找特定字符、子字符串还是模式匹配,掌握有效的字符串搜索方法对于编程效率和性能优化至关重要。本文将揭示三种常用的JavaScript字符串搜索技术:indexOfincludes和KMP算法,并通过实际代码示例展示如何在数据采集的情况下实现这些技术。

概述

  1. 基本字符串方法
    • indexOf()
    • includes()
    • search()
    • match()
  2. 高级字符串搜索算法
    • KMP算法(Knuth-Morris-Pratt)
  3. 实现数据采集的字符串搜索

    细节

    基本字符串方法

    indexOf()

    indexOf()方法返回在调用该方法的字符串中找到的第一个子字符串的索引,如果未找到,则返回-1。

    let text = "hello world";
    let searchString = "world";
    console.log(text.indexOf(searchString)); // 输出:6
    
    includes()

    includes()方法检查一个字符串是否包含另一个子字符串,返回布尔值。

    let text = "hello world";
    let searchString = "world";
    console.log(text.includes(searchString)); // 输出:true
    

    KMP算法

    KMP算法是一种高效的字符串搜索算法,特别适用于在大文本中搜索长模式的情况。它的时间复杂度为O(n + m),比简单的暴力匹配算法更高效。
    ```javascript
    // KMP字符串搜索算法实现
    function kmpSearch(pattern, text) {
    if (pattern.length === 0) return 0;

    let lsp = [0];
    for (let i = 1; i < pattern.length; i++) {
    let j = lsp[i - 1];
    while (j > 0 && pattern[i] !== pattern[j]) {
    j = lsp[j - 1];
    }
    if (pattern[i] === pattern[j]) {
    j++;
    }
    lsp.push(j);
    }

    let j = 0;
    for (let i = 0; i < text.length; i++) {
    while (j > 0 && text[i] !== pattern[j]) {
    j = lsp[j - 1];
    }
    if (text[i] === pattern[j]) {
    j++;
    if (j === pattern.length) {

     return i - (j - 1);
    

    }
    }
    }
    return -1;
    }

let text = "haystack";
let pattern = "needle";
console.log(kmpSearch(pattern, text) !== -1); // 输出:false

#### 数据采集中实现字符串搜索
下面的示例展示了如何结合数据采集与上述字符串搜索方法。请注意在实际的网络爬虫中,我们常常需要使用代理IP来隐藏真实IP地址,防止被目标网站封禁。
```javascript
const axios = require('axios');
const querystring = require('querystring');

// 代理IP配置 亿牛云爬虫代理标准版
const proxy = {
  host: 'www.host.cn', // 代理IP地址
  port: 12345,              // 代理端口
  auth: {
    username: 'yourUsername', // 代理用户名
    password: 'yourPassword'  // 代理密码
  }
};

// KMP字符串搜索算法实现
function kmpSearch(pattern, text) {
  if (pattern.length === 0) return 0;

  let lsp = [0];
  for (let i = 1; i < pattern.length; i++) {
    let j = lsp[i - 1];
    while (j > 0 && pattern[i] !== pattern[j]) {
      j = lsp[j - 1];
    }
    if (pattern[i] === pattern[j]) {
      j++;
    }
    lsp.push(j);
  }

  let j = 0;
  for (let i = 0; i < text.length; i++) {
    while (j > 0 && text[i] !== pattern[j]) {
      j = lsp[j - 1];
    }
    if (text[i] === pattern[j]) {
      j++;
      if (j === pattern.length) {
        return i - (j - 1);
      }
    }
  }
  return -1;
}

// 搜索关键词“新闻”
const searchKeyword = '新闻';
const searchUrl = `https://www.baidu.com/s?${querystring.stringify({ wd: searchKeyword })}`;

// 使用代理IP发送HTTP请求访问百度搜索结果页面
axios.get(searchUrl, { proxy: proxy })
  .then(response => {
    let text = response.data;
    let searchString = "中国"; // 要搜索的字符串

    // 使用indexOf方法
    console.log('Using indexOf:', text.indexOf(searchString) !== -1);

    // 使用includes方法
    console.log('Using includes:', text.includes(searchString));

    // 使用KMP算法
    console.log('Using KMP:', kmpSearch(searchString, text) !== -1);
  })
  .catch(error => {
    console.error('Error fetching the page:', error);
  });

在这个代码示例中,我们通过百度的搜索接口进行搜索关键词“新闻”,然后检查搜索结果页面中是否包含字符串“中国”。使用了axios库进行HTTP请求,并配置了代理IP,以确保请求通过代理服务器发送。

结论

本文介绍了三种常用的JavaScript字符串搜索技术:indexOfincludes和KMP算法,并提供了结合爬虫代理IP技术的实现示例。掌握这些方法可以帮助开发者在各种场景中高效地进行字符串搜索和匹配。希望这篇文章对你理解和应用JavaScript字符串搜索有所帮助。

相关文章
|
1月前
|
存储 监控 算法
局域网监控其他电脑的设备信息管理 Node.js 跳表算法
跳表通过分层索引实现O(logn)的高效查询、插入与删除,适配局域网监控中设备动态接入、IP映射及范围筛选等需求,相比传统结构更高效稳定,适用于Node.js环境下的实时设备管理。
108 9
|
3月前
|
存储 监控 JavaScript
基于布隆过滤器的 Node.js 算法在局域网电脑桌面监控设备快速校验中的应用研究
本文探讨了布隆过滤器在局域网电脑桌面监控中的应用,分析其高效空间利用率、快速查询性能及动态扩容优势,并设计了基于MAC地址的校验模型,提供Node.js实现代码,适用于设备准入控制与重复数据过滤场景。
184 0
|
1月前
|
存储 监控 JavaScript
企业上网监控系统的恶意 URL 过滤 Node.js 布隆过滤器算法
布隆过滤器以低内存、高效率特性,解决企业上网监控系统对百万级恶意URL实时检测与动态更新的难题,通过概率性判断实现毫秒级过滤,内存占用降低96%,适配大规模场景需求。
214 3
|
1月前
|
存储 监控 算法
电脑管控软件的进程优先级调度:Node.js 红黑树算法
红黑树凭借O(log n)高效插入、删除与查询特性,适配电脑管控软件对进程优先级动态调度的高并发需求。其自平衡机制保障系统稳定,低内存占用满足轻量化部署,显著优于传统数组或链表方案,是实现关键进程资源优先分配的理想选择。
119 1
|
2月前
|
运维 监控 JavaScript
基于 Node.js 图结构的局域网设备拓扑分析算法在局域网内监控软件中的应用研究
本文探讨图结构在局域网监控系统中的应用,通过Node.js实现设备拓扑建模、路径分析与故障定位,提升网络可视化、可追溯性与运维效率,结合模拟实验验证其高效性与准确性。
227 3
|
6月前
|
存储 机器学习/深度学习 算法
KMP、Trie树 、AC自动机‌ ,三大算法实现 优雅 过滤 netty 敏感词
KMP、Trie树 、AC自动机‌ ,三大算法实现 优雅 过滤 netty 敏感词
KMP、Trie树 、AC自动机‌ ,三大算法实现 优雅 过滤 netty  敏感词
|
6月前
|
监控 算法 JavaScript
基于 JavaScript 图算法的局域网网络访问控制模型构建及局域网禁止上网软件的技术实现路径研究
本文探讨局域网网络访问控制软件的技术框架,将其核心功能映射为图论模型,通过节点与边表示终端设备及访问关系。以JavaScript实现DFS算法,模拟访问权限判断,优化动态策略更新与多层级访问控制。结合流量监控数据,提升网络安全响应能力,为企业自主研发提供理论支持,推动智能化演进,助力数字化管理。
175 4
|
6月前
|
监控 算法 JavaScript
公司局域网管理视域下 Node.js 图算法的深度应用研究:拓扑结构建模与流量优化策略探析
本文探讨了图论算法在公司局域网管理中的应用,针对设备互联复杂、流量调度低效及安全监控困难等问题,提出基于图论的解决方案。通过节点与边建模局域网拓扑结构,利用DFS/BFS实现设备快速发现,Dijkstra算法优化流量路径,社区检测算法识别安全风险。结合WorkWin软件实例,展示了算法在设备管理、流量调度与安全监控中的价值,为智能化局域网管理提供了理论与实践指导。
179 3
|
5月前
|
机器学习/深度学习 监控 算法
局域网行为监控软件 C# 多线程数据包捕获算法:基于 KMP 模式匹配的内容分析优化方案探索
本文探讨了一种结合KMP算法的多线程数据包捕获与分析方案,用于局域网行为监控。通过C#实现,该系统可高效检测敏感内容、管理URL访问、分析协议及审计日志。实验表明,相较于传统算法,KMP在处理大规模网络流量时效率显著提升。未来可在算法优化、多模式匹配及机器学习等领域进一步研究。
168 0
|
7月前
|
JavaScript
JS实现多条件搜索函数
JS封装的多条件搜索
下一篇
oss云网关配置