首页 \ 问答 \ 如何精确搜索和替换(How to search and replace precisely)

如何精确搜索和替换(How to search and replace precisely)

我有一个文本文件,其内容非常类似于以下内容

G12

G10,11

GO12

GO10,12

我要做的是将所有'G'替换为'',而不是将'GO'替换为'O'。

我正在尝试使用正则表达式,所以首先我处理的是没有逗号的行

with open(file) as f:
for line in f:
if re.match(r"%s[0-9]+" % 'G', line):
    input = line.strip('G')

事实证明,“G10,11 \ n”字符串也匹配正则表达式模式,这让我感到困惑。

我的陈述是否有任何问题,或者有更简单的方法吗? 非常感谢,


I have a text file which content is quite like following

G12

G10,11

GO12

GO10,12

What I am trying to do is replace all the 'G' with '' but not replacing 'GO' to 'O'.

I was trying to do with regular expressions, so first I am dealing with the lines without a comma

with open(file) as f:
for line in f:
if re.match(r"%s[0-9]+" % 'G', line):
    input = line.strip('G')

And it turns out that the "G10,11\n" string is matching the regex pattern either, which makes me confused.

Is there any wrong with my statement, OR is there any simpler approach to do this? Many thanks,


原文:https://stackoverflow.com/questions/21983626
更新时间:2022-01-17 19:01

最满意答案

尝试这个:

Dim sourceSht As Worksheet
Dim myrange As Range
Dim DestRow As Integer
Dim ws2 As Worksheet
Dim MonthVal As String
Dim rw As Range

Range("D3").Select
ActiveCell.FormulaR1C1 = "=MONTH(R[-1]C)"
Range("D3").Select
Selection.NumberFormat = "General"
MonthVal = ActiveCell.Value

Set sourceSht = ThisWorkbook.Worksheets("Signed")
Set myrange = sourceSht.Range("Y1:Y" & sourceSht.UsedRange.Row - 1 + sourceSht.UsedRange.Rows.Count)
Set ws2 = Sheets("April")
DestRow = ws2.Cells(Rows.Count, "A").End(xlUp).Row ' + 1

For Each rw In myrange '.Rows
    If sourceSht.Cells(rw.Row, 12).Value = MonthVal Then
        DestRow = DestRow + 1
        rw.Copy Destination:=Sheets("April").Range("A" & DestRow)
    End If
Next rw

编辑:修复第15行的潜在漏洞(从Set myrange = sourceSht.Range("Y1:y" & sourceSht.UsedRange.Rows.Count)Set myrange = sourceSht.Range("Y1:Y" & sourceSht.UsedRange.Row - 1 + sourceSht.UsedRange.Rows.Count) ),以防顶部有未使用的行。


Try this:

Dim sourceSht As Worksheet
Dim myrange As Range
Dim DestRow As Integer
Dim ws2 As Worksheet
Dim MonthVal As String
Dim rw As Range

Range("D3").Select
ActiveCell.FormulaR1C1 = "=MONTH(R[-1]C)"
Range("D3").Select
Selection.NumberFormat = "General"
MonthVal = ActiveCell.Value

Set sourceSht = ThisWorkbook.Worksheets("Signed")
Set myrange = sourceSht.Range("Y1:Y" & sourceSht.UsedRange.Row - 1 + sourceSht.UsedRange.Rows.Count)
Set ws2 = Sheets("April")
DestRow = ws2.Cells(Rows.Count, "A").End(xlUp).Row ' + 1

For Each rw In myrange '.Rows
    If sourceSht.Cells(rw.Row, 12).Value = MonthVal Then
        DestRow = DestRow + 1
        rw.Copy Destination:=Sheets("April").Range("A" & DestRow)
    End If
Next rw

Edit: fixed a potential loophole at line 15 (from Set myrange = sourceSht.Range("Y1:y" & sourceSht.UsedRange.Rows.Count) to Set myrange = sourceSht.Range("Y1:Y" & sourceSht.UsedRange.Row - 1 + sourceSht.UsedRange.Rows.Count)), in case there are unused rows at the top.

相关问答

更多

相关文章

更多

最新问答

更多
  • 如何使用自由职业者帐户登录我的php网站?(How can I login into my php website using freelancer account? [closed])
  • 如何打破按钮上的生命周期循环(How to break do-while loop on button)
  • C#使用EF访问MVC上的部分类的自定义属性(C# access custom attributes of a partial class on MVC with EF)
  • 如何获得facebook app的publish_stream权限?(How to get publish_stream permissions for facebook app?)
  • 如何并排放置两个元件?(How to position two elements side by side?)
  • 在MySQL和/或多列中使用多个表用于Rails应用程序(Using multiple tables in MySQL and/or multiple columns for a Rails application)
  • 如何隐藏谷歌地图上的登录按钮?(How to hide the Sign in button from Google maps?)
  • Mysql左连接旋转90°表(Mysql Left join rotate 90° table)
  • 带有ImageMagick和许多图像的GIF动画(GIF animation with ImageMagick and many images)
  • 电脑高中毕业学习去哪里培训
  • 电脑系统专业就业状况如何啊?
  • IEnumerable linq表达式(IEnumerable linq expressions)
  • 如何在Spring测试中连接依赖关系(How to wire dependencies in Spring tests)
  • Solr可以在没有Lucene的情况下运行吗?(Can Solr run without Lucene?)
  • 如何保证Task在当前线程上同步运行?(How to guarantee that a Task runs synchronously on the current thread?)
  • 在保持每列的类的同时向数据框添加行(Adding row to data frame while maintaining the class of each column)
  • 的?(The ? marks in emacs/haskell and ghc mode)
  • 一个线程可以调用SuspendThread传递自己的线程ID吗?(Can a thread call SuspendThread passing its own thread ID?)
  • 延迟socket.io响应,并“警告 - websocket连接无效”(Delayed socket.io response, and “warn - websocket connection invalid”)
  • 悬停时的图像转换(Image transition on hover)
  • IIS 7.5仅显示homecontroller(IIS 7.5 only shows homecontroller)
  • 没有JavaScript的复选框“关闭”值(Checkbox 'off' value without JavaScript)
  • java分布式框架有哪些
  • Python:填写表单并点击按钮确认[关闭](Python: fill out a form and confirm with a button click [closed])
  • PHP将文件链接到根文件目录(PHP Linking Files to Root File Directory)
  • 我如何删除ListView中的项目?(How I can remove a item in my ListView?)
  • 您是否必须为TFS(云)中的每个BUG创建一个TASK以跟踪时间?(Do you have to create a TASK for every BUG in TFS (Cloud) to track time?)
  • typoscript TMENU ATagParams小写(typoscript TMENU ATagParams lowercase)
  • 武陟会计培训类的学校哪个好点?
  • 从链接中删除文本修饰(Remove text decoration from links)