我需要删除以空格开头的行(整行,而不仅仅是空格)
这是我正在使用的文件的示例:
41. 415607DB (AV-2011) 2007-06-23 (1D0703A2) (572D8DEC)
42. 415607DC (AV-2012) 2007-06-21 (4A5E805B) (73A29D08)
2009-11-18 (F830F241) (11F8A118)
43. 415607DD (AV-2013) 2007-07-12 (2D92F988) (2CB96AE4)
44. 415607DE (AV-2014) 2009-08-18 (A8E5F41B) (614BF7F6)
45. 415607DF (AV-2015) 2008-06-21 (8A3A88B8) (3B7CBB2D)
46. 415607E0 (AV-2016) 2011-03-29 (EF1BE81D) (2641EDA1)
2007-06-27 (7C19F25E) (1B17FCD8)
47. 415607E1 (AV-2017) 2007-11-21 (608D1D2F) (720B9353)
2007-11-29 (E55CEF10) (1BB2F934)
2007-06-21 (DD85E9F6) (2E07093A)
48. 415607E2 (AV-2018) 2009-07-07 (3D7B9FC0) (0F8AB402)
这是我希望获得的输出:
41. 415607DB (AV-2011) 2007-06-23 (1D0703A2) (572D8DEC)
42. 415607DC (AV-2012) 2007-06-21 (4A5E805B) (73A29D08)
43. 415607DD (AV-2013) 2007-07-12 (2D92F988) (2CB96AE4)
44. 415607DE (AV-2014) 2009-08-18 (A8E5F41B) (614BF7F6)
45. 415607DF (AV-2015) 2008-06-21 (8A3A88B8) (3B7CBB2D)
46. 415607E0 (AV-2016) 2011-03-29 (EF1BE81D) (2641EDA1)
47. 415607E1 (AV-2017) 2007-11-21 (608D1D2F) (720B9353)
48. 415607E2 (AV-2018) 2009-07-07 (3D7B9FC0) (0F8AB402)
^\h+.*$\R?
LEAVE EMPTY
. matches newline
解释:
截图(之前):
截图(之后):
使用纯正则表达式解决方案是可能的(请参阅@Toto 的答案),但也许使用书签的以下解决方案更容易掌握:
打开查找对话框
转到标记选项卡,搜索
^
(即 2 个字符:表示“行首”的插入符号和空格)并启用“书签行”选项。我假设您的搜索模式已设置为正则表达式。点击“全部标记”按钮。删除所有带书签的行(搜索→书签→删除带书签的行)
你可以这样做:
按 Ctrl+H 进行查找和替换。
复选标记正则表达式。
使用查找框中的正则表达式
^\s+.*
。保持替换框空白。
单击全部替换。
另一个似乎适用于您的示例的解决方案是
Select All
(Ctrl-A),然后转到Edit
>Line Operations
>Sort Lines [pick one of them that best applies]
,这会将所有以空格开头的行分组在一起,然后您可以轻松地选择并删除它们. 这仅在这种情况下有效,因为您要保留的行似乎已经按数字排序。显然,如果您不想更改其他行的排序,这可能不适用。就个人而言,我拥有
Sort Lines Lexicographically Ascending
并Sort Lines as Integers Ascending
分配了热键,因为我经常将它们用于这类事情。我知道这是一个记事本问题,但我无法抗拒。
在 vim 中,你可以这样做
其中说删除所有以空格开头的行。
您可以编写自动化脚本,例如
或者,如果您需要处理流,请使用 sed: