首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

(转载)Linux之sed匹配第N个进行替换

第二个句子是通过循环把文本全部读进pattern space 然后只替换第一个。 替换第N[3]个88为--: sed '/88/{x;s/^/./;/^\.\{3\}$/{x;s/....第二个命令和上面第一个其实是一样的原理,全部读入文本后统一替换第3个匹配的内容。 替换最后一个匹配的88为--: sed ':a;/\n88/!....*\)88/\1--/' file [解析] 第一个命令,没匹配到 /\n88/ 的内容就读取下一行,然后 ba 跳转去开始处,如果读取到88的行呢,就执行后面的 P;D 组合,D也有循环功能,一直把匹配...一直到匹配到最后一个88的行,继续读取到末行时执行替换,N 因为没有下一行可读,所以会自动中止命令,因为没有 -n 参数会打印 pattern space 里的内容到屏幕,所以就不会再执行后面的 ba...» 本文链接:(转载)Linux之sed匹配第N个进行替换 » 转载请注明来源:刺客博客

9.2K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    linux下sed正则表达式匹配批量替换文件中的内容

    l 列表不能打印字符的清单 n 读取下一个输入行,用下一个命令处理新的行而不是第一个命令 N 追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码 p 打印模板块的行 P 打印模板块的第一行...x 表示互换模板块中的文本和缓冲区中的文本 y 表示把一个字符翻译为另外的字符(但是不用于正则表达式) \1 子串匹配标记 & 已匹配字符串标记 当然要使用其功能需要对正则表达式有一定了解。...替换hello成world,并打印到屏幕上 sed 's/hello/world/' hello.txt s 表示替换 hello 表示匹配的字母,是正则表达式 world 表示需要替换成的字母...只显示被匹配的行 sed -n 's/hello/world/p' hello.txt n和p的意思上文有介绍 不再解释。 执行结果: ?...替换文件中的内容,并写到文件里 sed -i 's/o/ABC/' hello.txt 执行结果: 执行cat查看文件内容: ? 可以看到虽然替换了,但是只替换了第一个被匹配的到内容。

    6K10

    Excel公式技巧65:获取第n个匹配的值(使用VLOOKUP函数)

    如下图1所示的工作表,在“商品”列中,存在一些重复的商品,现在我们要找出第2次出现的“笔记本”的销售量。 ?...图1 我们知道VLOOKUP函数通常会返回找到的第一个匹配值,或者最后一个匹配值,详见《Excel公式技巧62:查找第一个和最后一个匹配的数据》。...然而,我们可以构造一个与商品相关的具有唯一值的辅助列(详见《Excel公式技巧64:为重复值构造包含唯一值的辅助列》),从而可以使用VLOOKUP函数来实现查找匹配值。...首先,添加一个具有唯一值的辅助列,如下图2所示。 ? 图2 在单元格B3中输入公式: =D3 & "-" &COUNTIF( 下拉至单元格B14。...在单元格H6中输入公式: =VLOOKUP(H2 & "-" &G6,B3:E 即可得到指定的匹配值,如下图3所示。 ? 图3 可以修改单元格H2或G6中的数值,从而获取相应匹配的数据。

    7.9K10

    Excel公式技巧66:获取第n个匹配的值(使用INDEX函数)

    学习Excel技术,关注微信公众号: excelperfect 在《Excel公式技巧65:获取第n个匹配的值(使用VLOOKUP函数)》中,我们构造了一个没有重复值的辅助列,从而可以使用VLOOKUP...本文中仍然以此为例,使用INDEX函数来获取重复值中指定的值,但是不需要构造辅助列。 如下图1所示的工作表,在“商品”列中,存在一些重复的商品,现在我们要找出第2次出现的“笔记本”的销售量。 ?...图2 公式中: C3:C14=G2 将单元格区域C3:C14中的值与单元格G2中的值相比较,得到由布尔值组成的数组: {TRUE;FALSE;FALSE;FALSE;FALSE;TRUE;FALSE;FALSE...;FALSE;FALSE;TRUE;TRUE} 公式中: ROW(C3:C14)-ROW(C3)+1 生成一系列由1至单元格区域的最大个数的连续整数组成的数组: {1;2;3;4;5;6;7;8;9;10...代入INDEX函数中,得到: =INDEX(D3:D14,6) 结果为单元格D8中的值10。 如果使用定义的名称,那么公式将更灵活,如下图3所示。 ?

    6.7K10

    Python快速计算Fibonacci数列中第n项的方法

    1 return fibo1(n-1) + fibo1(n-2) @lru_cache(maxsize=64) def fibo2(n): '''递归法,使用缓存修饰器加速''' if n in...range(2, n+1): a, b = b, a+b return a # 测试3个函数的执行速度 n = 40 for fibo in (fibo1, fibo2, fibo3...267914296:67.31945824623108 fibo2:267914296:0.0 fibo3:267914296:0.0 由于第一个函数运行速度非常慢,在n变大时只测试后面2个函数的执行时间...380时,第二个函数由于递归深度过大而崩溃,抛出异常: RecursionError: maximum recursion depth exceeded while calling a Python object...下面继续测试第3个函数,当n=500时,运行结果为: fibo3:139423224561697880139724382870407283950070256587697307264108962948325571622863290691557658876222521294125

    1.4K70

    Python中的正则表达式及其常用匹配函数用法简介

    Python正则表达式的简单应用和示例演示 这次给大家主要是介绍Python中的正则表达式,及其相关函数的基本使用方法,并且捎带一些正则表达式给我们带来的便利。...compile 函数根据一个模式字符串和可选的标志参数生成一个正则表达式对象。该对象拥有一系列方法用于正则表达式匹配和替换。.../4 检索和替换/ Python 的re模块提供了re.sub用于替换字符串中的匹配项。...repl : 替换的字符串,也可为一个函数。 string : 要被查找替换的原始字符串。 count : 模式匹配后替换的最大次数,默认 0 表示替换所有的匹配。.../8 正则表达式模式/ 模式字符串使用特殊的语法来表示一个正则表达式: 字母和数字表示他们自身。一个正则表达式模式中的字母和数字匹配同样的字符串。

    1.3K20

    【从零学习python 】67.Python中的re模块:正则替换与高级匹配技术

    正则替换 Python中的re模块提供了re.sub用于替换字符串中的匹配项。...语法: re.sub(pattern, repl, string, count=0) 参数: pattern:正则中的模式字符串。 repl:替换的字符串,也可为一个函数。...string:要被查找替换的原始字符串。 count:模式匹配后替换的最大次数,默认0表示替换所有的匹配。...示例代码: phone = "2004-959-559 # 这是一个电话号码" # 删除注释 num = re.sub(r'#.*$', "", phone) print("电话号码:", num)...# 移除非数字的内容 num = re.sub(r'\D', "", phone) print("电话号码:", num) 除了可以使用一个字符串来表示替换后的结果外,repl还可以传入一个函数。

    7510

    LeetCode-19 删除链表中的倒数第N个节点

    删除链表中的倒数第N个节点 > 难度:中等 > 分类:链表 > 解决方案:双指针 今天我们学习第19题删除链表中的倒数第N个节点,这是一道中等题。这个题属于面试中的高频题,一定要能手写出来。...下面我们看看这道题的题目描述。 题目描述 给定一个链表,删除链表的倒数第 n个节点,并且返回链表的头结点。...这个题让我们删除链表中的倒数第 n个节点,并且返回头节点。题目中说明部分提到给定的 n保证是有效的,因此 n的值小于等于链表的长度。...Github地址 LeetCode-19 删除链表中的倒数第N个节点:https://github.com/JacobLei/leetcode/blob/master/src/main/java/A19..._RemoveNthNodeFromEndofList.java 参考链接 删除链表中的倒数第N个节点:https://leetcode-cn.com/problems/remove-nth-node-from-end-of-list

    46810

    python用re.sub实现分组匹配和替换(及问答系统中的应用)

    关于正则表达式替换,前面我写过一个应用: python2代码搬运到python3要改很多print?...试试用pyCharm的正则表达式替换 其实这里的替换已经使用了分组的思想。...上面一行的匹配模式print (\S*)中,括号括起的部分匹配到的内容就被识别为匹配组1。而下一行的替换模式中,$1就指代了匹配组1的内容。...所以在这个例子里,匹配组1匹配到的内容是“123”,而在替换时,“123”就替换了$1对应的位置。 有时候,我们可能需要从一句话中提取多个分组,并且替换其中的全部,或者仅仅是部分几组。...,quest) 曹丕的父亲是曹操 其中的\1,\2就表示第1、第2匹配组的内容(“曹丕”、“父亲”)。

    4.1K10

    PHP中的正则表达式及模式匹配

    PHP中对于正则处理文本提供了两种方式,一种是PCRE方式(PCRE库是一个实现了与perl 5在语法和语义上略有差异(详见下文)的正则表达式模式匹配功能的函数集....如果目标字符串中没有“\n”字符或者模式中没有 ^ 或 $,则设定此修正符没有任何效果。...如果这个修饰符 没有设置, 当字符串以一个换行符结尾时, 美元符号还会匹配该换行符(但不会匹配之前的任何换行符). 如果设置了修饰符m, 这个修饰符被忽略. 在perl中没有与此修饰符等同的修饰符....模式中的任意反斜线后就ingen一个 没有特殊含义的字符都会导致一个错误, 以此保留这些字符以保证向后兼容性. 默认 情况下, 在perl中, 反斜线紧跟一个没有特殊含义的字符被认为是该字符的原文....参考资料: 1、preg_match_all截取body正则表达式 2、PHP正则表达式匹配多行及模式匹配 3、PHP Manual PCRE模式 @import url(http://www.cnblogs.com

    2.9K20

    Python正则表达式如何匹配中间的内容?

    一、前言 前几天在Python最强王者交流群【Chloe】问了一道正则表达式处理的问题,如下图所示。...这里【月神】都给了一个正则表达式写法,如下所示。...运行之后,结果如下图所示: 方法三 后来【Python进阶者】也给了一个正则表达式写法,只需要将正则那块改成下面的代码即可。 s = re.findall(r'9910.*?Ave....当然了,上面那个正则表达式中的?也可以去除,一样可以得到结果。 ?表明是非贪婪模式,解析如下。 最后给大家安利下re.search 和 re.findall的区别。 三、总结 大家好,我是皮皮。...这篇文章主要盘点了一道正则表达式的问题,文中针对该问题给出了具体的解析和代码实现,还做了贪婪模式和非贪婪模式的探讨,帮助粉丝顺利解决了问题。

    1.3K10
    领券