python - 如何查询数据框两列的值

标签 python pandas function lambda

假设我有一个包含以下列的数据框,

df.head()
    ref_loc ref_chr REF ALT coverage    base
    9532728 21  G   [A] 1   A
    9540473 21  C   [G] 2   G
    9540473 21  CTATT   [C] 2   G
    9540794 21  C   [T] 1   A
    9542965 21  C   [A] 1   T

我想比较列 ALT 和列 base 并查看匹配项和差异项。基于匹配和差异,我想生成一个名为 cate 的新列。

为此,我尝试使用以下函数,

def grouping(row):
    if row['ALT'] == row['base']:
         val = "same_variants"
    elif row['ALT'] != row['base']:
         val = "diff_variants"
    return val

df["cate"] = df.apply(grouping,axis=0)

但是,尝试在数据帧上应用该函数时会抛出此错误,

    KeyError                                  Traceback (most recent call last)
<ipython-input-13-a265dee72ec1> in <module>
----> 1 df["group"] =df.apply(grouping,axis=0)

~/software/anaconda/lib/python3.7/site-packages/pandas/core/frame.py in apply(self, func, axis, broadcast, raw, reduce, result_type, args, **kwds)
   6911             kwds=kwds,
   6912         )
-> 6913         return op.get_result()
   6914 
   6915     def applymap(self, func):

~/software/anaconda/lib/python3.7/site-packages/pandas/core/apply.py in get_result(self)
    184             return self.apply_raw()
    185 
--> 186         return self.apply_standard()
    187 
    188     def apply_empty_result(self):

~/software/anaconda/lib/python3.7/site-packages/pandas/core/apply.py in apply_standard(self)
    290 
    291         # compute the result using the series generator
--> 292         self.apply_series_generator()
    293 
    294         # wrap results

~/software/anaconda/lib/python3.7/site-packages/pandas/core/apply.py in apply_series_generator(self)
    319             try:
    320                 for i, v in enumerate(series_gen):
--> 321                     results[i] = self.f(v)
    322                     keys.append(v.name)
    323             except Exception as e:

<ipython-input-11-098066170c2f> in grouping(row)
      1 def grouping(row):
----> 2     if row['ALT'] == row['base']:
      3          val = "same_variants"
      4     elif row['ALT'] != row['base']:
      5          val= "diff_variants"

~/software/anaconda/lib/python3.7/site-packages/pandas/core/series.py in __getitem__(self, key)
   1066         key = com.apply_if_callable(key, self)
   1067         try:
-> 1068             result = self.index.get_value(self, key)
   1069 
   1070             if not is_scalar(result):

~/software/anaconda/lib/python3.7/site-packages/pandas/core/indexes/base.py in get_value(self, series, key)
   4728         k = self._convert_scalar_indexer(k, kind="getitem")
   4729         try:
-> 4730             return self._engine.get_value(s, k, tz=getattr(series.dtype, "tz", None))
   4731         except KeyError as e1:
   4732             if len(self) > 0 and (self.holds_integer() or self.is_boolean()):

pandas/_libs/index.pyx in pandas._libs.index.IndexEngine.get_value()

pandas/_libs/index.pyx in pandas._libs.index.IndexEngine.get_value()

pandas/_libs/index.pyx in pandas._libs.index.IndexEngine.get_loc()

pandas/_libs/index_class_helper.pxi in pandas._libs.index.Int64Engine._check_type()

KeyError: ('ALT', 'occurred at index ref_loc')

我想提出一些我可以继续前进的建议。

最后,输出应该如下所示,

ref_loc ref_chr REF ALT coverage    base    cate
9532728 21  G   [A]      1         A      same_variants
9540473 21  C   [G]      2         G      same_variants
9540473 21  CTATT   [C]  2         G      diff_variants
9540794 21  C   [T]      1         A      diff_variants
9542965 21  C   [A]      1         T      diff_variants

最佳答案

请注意,由于 ALT 列周围有方括号,因此它总是不同的。可以先把括号里面的内容提取出来:
df["ALT"] = df.ALT.apply(lambda l: l[0])

您需要使用 axis=1 来遍历行。 axis=0 遍历列。

df["cate"] = df.apply(grouping,axis=1)
print(df)
   ref_loc  ref_chr    REF ALT  coverage base           cate
0  9532728       21      G   A         1    A  same_variants
1  9540473       21      C   G         2    G  same_variants
2  9540473       21  CTATT   C         2    G  diff_variants
3  9540794       21      C   T         1    A  diff_variants
4  9542965       21      C   A         1    T  diff_variants

关于python - 如何查询数据框两列的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58954764/

相关文章:

python - 如何在不修改 Python 中的原始列表的情况下反转列表

pandas 从列列表中分配结果

python - Openpyxl 无法读取 xlsx 文件,但如果我保存文件,它会打开

python - Fillna 如果出现频率最高,则 fillna 为整个列中出现频率最高的值

python - 如何在 python 3 中将复杂的数据帧值转换为 float ?

php - 用 PHP 调用 JavaScript

java - 函数退出后,函数内部打开的文件/文件指针(缓冲读取器)会发生什么?

javascript - 你能识别这个用 javascript 编写的哈希函数吗?

python - Python X 秒后超时

python - 使用外部 .kv 文件与内部处理?