小编Bru*_*ica的帖子

负面的lookbehind断言正则表达式与grep -P有意想不到的结果

我正在测试以下否定的lookbehind断言,我想了解结果:

echo "foo foofoo" | grep -Po '(?<!foo)foo'
Run Code Online (Sandbox Code Playgroud)

它打印出来

foo
foo
foo
Run Code Online (Sandbox Code Playgroud)

我期待只打印两个第一个foo,'echo foo foo foo'而不是第三个foo,因为我的断言应该意味着找到'foo'之前没有'foo'.

我错过了什么?为什么第三个foo匹配?

注意:grep -P意味着将正则表达式解释为perl兼容的正则表达式.grep -o表示只打印匹配的字符串.我的grep是2.5.1版.

regex linux grep pcre

5
推荐指数
1
解决办法
232
查看次数

如何用只有bash内置函数的字符串中的单个空格替换多个空格

我想用bash用一个空格替换字符串中的多个相邻空格.例:

原始字符串:

"too         many       spaces."
Run Code Online (Sandbox Code Playgroud)

转换字符串:

"too many spaces."
Run Code Online (Sandbox Code Playgroud)

我尝试了类似的东西"${str//*( )/.}",awk '{gsub(/[:blank:]/," ")}1'但我无法做到.

注意:我能够使它工作,<CMD_THAT_GENERATES_THE_INPUT_STRINGH> | perl -lpe's/\s+/ /g'但我不得不使用perl来完成这项工作.我想使用一些bash内部语法而不是调用外部程序,如果可能的话.

string bash shell replace

4
推荐指数
3
解决办法
2441
查看次数

如何使用 typeorm 向现有实体添加新列

我开始研究 typeorm 并且我对如果将新列添加到已经保存有数据的现有实体会发生什么感到困惑。我使用 SQLite。

我在文档的“迁移”部分看到,如果我想添加一个新列,似乎必须完成一个过程。

但是当我在 typeorm 的 github 中看到这个问题时,我明白如果我只是将新的“@Column”注释属性添加到 Entity 类就足够了,并且 typeorm 会在应用程序启动时自动创建列。

我真的希望 typeorm 能够自动处理该架构更改。

有人可以帮忙吗?

sqlite typeorm

3
推荐指数
1
解决办法
7499
查看次数

java 8 stream如何将Map <String,List <Strings >>转换为List <String>将所有的字符串值?

我有一张Map<String, List<String>>地图,我希望从中提取一个List<String>包含地图中所有字符串列表的字符串.我想使用java8流语法.

在旧的Java我会做:

List<String> all = new LinkedList<String>();
for (String key: map.keySet()) {
    all.addAll(map.get(key));
}
return all;
Run Code Online (Sandbox Code Playgroud)

如何使用流?

java java-8 java-stream

1
推荐指数
1
解决办法
463
查看次数

标签 统计

bash ×1

grep ×1

java ×1

java-8 ×1

java-stream ×1

linux ×1

pcre ×1

regex ×1

replace ×1

shell ×1

sqlite ×1

string ×1

typeorm ×1