首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如果column2对应于两个或多个column1值,则删除所有行

如果column2对应于两个或多个column1值,则删除所有行
EN

Unix & Linux用户
提问于 2021-06-10 10:42:28
回答 1查看 118关注 0票数 0

我有一个可分隔的选项卡,其中:

代码语言:javascript
复制
GL89     AADAC
GL89     AFGAC
GL89     AFDAC
GL50     AC923
GL50     AC923
GL79     AC923
GL99     AC923
GL99     AC923
GL60     AC100
GL60     AC100
GL20     AC200
GL30     AC300
GL30     AC400

我希望消除column#2的一个值至少对应于两个或多个column#1值的行,在这种情况下,应该删除下面的行。

代码语言:javascript
复制
GL50     AC923
GL79     AC923
GL99     AC923
GL99     AC923

把剩下的桌子留着:

代码语言:javascript
复制
GL89     AADAC
GL89     AFGAC
GL89     AFDAC
GL60     AC100
GL60     AC100
GL20     AC200
GL30     AC300
GL30     AC400

有什么表格吗?谢谢!

EN

回答 1

Unix & Linux用户

发布于 2021-06-10 21:10:34

解决此问题的适当数据结构是setdictionary

巨蟒都内置了。

代码语言:javascript
复制
python3 -c 'import sys
ifile = sys.argv[1]
fs,ors = "\t","\n"

d = {}; L = {}
with open(ifile) as fh:
  for l in fh:
    c1,c2 = l.rstrip().split(fs)
    if c2 in d:
      d[c2].add(c1)
      L[c2].append(l.rstrip())
    else:
      d[c2] = { c1 }
      L[c2] = [ l.rstrip() ]

print(*[l
  for k,v in d.items()
  if len(v) == 1
  for l in L[k]
  ], sep=ors)
' file

输出:

代码语言:javascript
复制
GL89    AADAC
GL89    AFGAC
GL89    AFDAC
GL60    AC100
GL60    AC100
GL20    AC200
GL30    AC300
GL30    AC400
票数 1
EN
页面原文内容由Unix & Linux提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://unix.stackexchange.com/questions/653683

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档