- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我希望能够删除句号后第一个大写的单词。目标是删除以大写字母写的第一个单词,即使同一行上的句子是两个。事实上,正如我将在示例中展示的那样,该行的第一个词已被省略,但出现了第二个句子的第一个词。
对于第一行的第一句话,我通过从 2 而不是 1 开始 if 来解决问题:
这是代码
BEGIN { FS="[^[:alpha:]']+"; OFS=" "}
{
parola=" "
max_nr=0
prec=""
for (i=2; i<=NF; i++) {
if ($i ~ /[[:punct:][:digit:]]+[:space:]*[A-Z][']{0,1}[A-Z]{0,1}[a-z]+/){
continue
}
else{
if ($i ~ /[A-Z][']{0,1}[A-Z]{0,1}[a-z]+/){
if(!(prec=="")){
prec=prec" "$i
}
else{
prec=$i
}
}
else {
if(!(prec=="")){
words[prec]
prec=""
}
}
if (i==NF) {
max_nr=max_nr+1
for (word1 in words) {
for (word2 in words) {
if (word1 != word2) {
print parola"" word1","word2
}
}
delete words[word1]
}
}
}
}
}
END{
print FILENAME" "FNR
print i
print max_nr
}
这是test.txt的内容:
Today Jonathan played soccer with Martin. After the game, Martin and Jonathan were thirsty and then drank a fresh Lemon Soda.
Paolo went to Lisbon with an Easyjet plane. During the trip he met two of his dear friends, Peter and John.
这是命令的结果:
awk -f script.awk test.txt > output.csv
Lisbon,During
Lisbon,John
Lisbon,Peter
Lisbon,Easyjet
During,John
During,Peter
During,Easyjet
John,Peter
John,Easyjet
Peter,Easyjet
Jonathan,Martin After
Jonathan,Lemon Soda
Jonathan,Martin
Martin After,Lemon Soda
Martin After,Martin
Lemon Soda,Martin
预期的输出应该是:
Lisbon,John
Lisbon,Peter
Lisbon,Easyjet
John,Peter
John,Easyjet
Peter,Easyjet
Jonathan,Martin
Martin,Lemon Soda
Jonathan,Lemon Soda
有什么建议吗?
最佳答案
不要尝试为您完成所有工作 (I provided a solution for that previously),只需解决您在这个问题中提出的具体问题:
您正在使用 FS="[^[:alpha:]']+"
因此无法判断给定的任何字段(“单词”)之前的分隔符是否为 .
或其他。使用 FS='[.]'
或类似的作为您的起点,然后您就会知道每个字段之前的分隔符是行的开头或 .
然后您可以使用 split($i,f,/[^[:alpha:]']+/)
来隔离该字段(“句子”)中的每个子字段(“单词”)。例如:
$ cat tst.awk
BEGIN { FS="[[:space:]]*[.][[:space:]]*" }
{
for (sentenceNr=1; sentenceNr<=NF; sentenceNr++) {
sentence = $sentenceNr
numWords = split(sentence,words,/[^[:alpha:]\047]+/)
for (wordNr=2; wordNr<=numWords; wordNr++) {
word = words[wordNr]
if ( word ~ /^[[:upper:]]/ ) {
print NR, sentenceNr, wordNr, word
}
}
}
}
$ awk -f tst.awk file
1 1 2 Jonathan
1 1 6 Martin
1 2 4 Martin
1 2 6 Jonathan
1 2 14 Lemon
1 2 15 Soda
2 1 4 Lisbon
2 1 7 EasyJet
2 2 11 Peter
2 2 13 John
请注意,给定此输入:
$ cat file
Today Jonathan played soccer with Martin. After the game, Martin and Jonathan were thirsty and then drank a fresh Lemon Soda.
Paolo went to Lisbon with an EasyJet plane. During the trip he met two of his dear friends, Peter and John.
May lost her home. 10 Downing St is where the PM lives.
以上将输出:
$ awk -f tst.awk file
1 1 2 Jonathan
1 1 6 Martin
1 2 4 Martin
1 2 6 Jonathan
1 2 14 Lemon
1 2 15 Soda
2 1 4 Lisbon
2 1 7 EasyJet
2 2 11 Peter
2 2 13 John
3 2 2 Downing
3 2 3 St
3 2 7 PM
如果“Downing”不应该存在,则将代码更改为:
$ cat tst.awk
BEGIN { FS="[[:space:]]*[.][[:space:]]*" }
{
for (sentenceNr=1; sentenceNr<=NF; sentenceNr++) {
numWords = split($sentenceNr,words,/[^[:alpha:]\047]+/)
isSubsequent = 0
for (wordNr=1; wordNr<=numWords; wordNr++) {
word = words[wordNr]
if ( word ~ /^[[:upper:]]/ ) {
if ( isSubsequent++ ) {
print NR, sentenceNr, wordNr, word
}
}
}
}
}
$ awk -f tst.awk file
1 1 2 Jonathan
1 1 6 Martin
1 2 4 Martin
1 2 6 Jonathan
1 2 14 Lemon
1 2 15 Soda
2 1 4 Lisbon
2 1 7 EasyJet
2 2 11 Peter
2 2 13 John
3 2 3 St
3 2 7 PM
关于linux - 删除句点后的第一个大写单词,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56583235/
我有以下数据框 (df_hvl),列名“FzListe”和以下数据: FzListe 7MA1, 7OS1 7MA1, 7ZJB 7MA2, 7MA3, 7OS1 76G1, 7MA1, 7OS1 7
我有点小问题。仅当尝试写入的相同字符串/单词不存在时,我才想写入文件。在我的例子中,它是一个 IP 地址和端口,用“:”分隔。如果我手动写入文件,例如 193...:80 和 193...:22,它指
如何返回结果列中的单词示例? 我得到的最接近的是 [\W]{2,}[^,\W].+[?=,] ID 文本 我的结果(完全匹配) 预期(完全匹配) 1 词A,世界B,词C , 世界 B, 字B 2 wo
我想在引号之间得到一个字符串 我知道一个解决方案是: /'.*?'/ 但问题是它不适用于英语中的所有格或收缩格 例如: What is the name of Mario's brother in t
我应该在句子中找到出现最多的单词。 这是我尝试过的,但不起作用。 '); $max = -1; $resultWords = array(); $resultCount = array(); $i =
我是vim的新手。我正在尝试练习(最近阅读了一些教程),但是我发现我不能不突出显示“复制粘贴”中的字符/单词/行。 在Textmate中,我通常使用SHIFT + CTRL + LeftArrowKe
有谁知道一个JSON格式的英语词典,该词典具有(单词,定义和单词类型,例如名词/形容词/动词/副词) 这种格式: [ {"Word" : "Chair", "Definition" : "A
我正在做一些 javascript,同时我注意到我无法替换 html 标记内的“ document.getElementById('label').innerHTML = document.get
您好,我正在使用 groovy 2.1.5,我必须编写一个代码来显示具有给定路径的目录的内容/文件,然后它会备份文件并替换文件中的单词/字符串。 这是我用来尝试替换所选文件中的单词的代码 String
我正在准备一个实验,我想使用python编写程序以识别参与者说出的某些单词。 我在python中搜索了很多有关语音识别的内容,但结果却很复杂(例如CMUSphinx)。 我要实现的是一个程序,该程序接
假设我有以下代码: $size = 23.9 $size = "$size GB" write $size 我想在其他事情上使用相同的变量,即 if ($size -lt 20) {...} 这显然是
我想替换字符串中单词 Date 的所有情况,除非它是 Date()(即 Date 后跟括号)。这是一个字符串示例以及我最初尝试的内容: x gsub("Date", paste("Date:", S
我对 Java 和编程都很陌生,请记住这一点,请不要对我严厉 ^^。接下来,我最近用 Java 进行了一些培训,我喜欢这个挑战,但现在我只是陷入困境。我做了一些示例来查找用户输入的最大字符串,一切都很
我必须给一个数字x,并写x个字符串(单词)。我必须找到写得最多的那一篇。它可以工作,但是当我尝试从文件中读取它时,却没有。例如,如果我执行 a.out'' #include #include in
这里是学习者,如果这个问题看起来很荒谬,请多多包涵。假设我试图引用字符串中的字符而不是字符串本身,我该怎么做呢?我的意思是; 给定:var str = "我想知道一个大脑分散的计算机如何保持理智" 我
这是阿克沙塔。我一直在解析以下数据。我想单独获取每个单词。我可以有一个示例代码以便我可以继续吗 RTRV-HDR RH01 SIMULATOR 09-11-18 16 13 19 M R
我有一个任意字符串,它总是包含至少一个英文单词后跟一系列数字:"Hello World 1234" 我如何只提取 "Hello World" 来自字符串? 最佳答案 在我看来你需要反正则表达式: St
我正在尝试输入一个四个单词的句子,然后能够使用indexOf和子字符串单独打印出每个单词。有什么想法我做错了吗? 已编辑 那么这就是它应该的样子吗?我已经运行了两次,得到了两个不同的答案,所以我不确定
如何在文本开头查找短语(单词) 我需要非常快速的解决方案来查明文本是否以某些已知短语开头 我在 Mysql (innodb) 表中的短语如下: CREATE TABLE IF NOT EXISTS `
我在 MYSQL 表中有一本字典,该表由 240 000 个单词组成。例如,如果我有字母 G、I、G、S、N> 和 O 我想选择表中包含所有或部分这些字母(并且没有其他字母)的所有单词。 可接受的词语
我是一名优秀的程序员,十分优秀!