- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个来自这种形式的 DataFrame:
In [122]: df=pd.DataFrame({"A":["1,2,3","4,5,6",np.nan,"8"],"B":[6,7,8,9]})
In [123]: df
Out[123]:
A B
0 1,2,3 6
1 4,5,6 7
2 NaN 8
3 8 9
我想过滤 B 中的行,其中 A 中的列表包含特定值,例如“4”。
我试过使用这种语法:
df["B"][["4" in a for a in df["A"].str.split(',')]]
但我得到 TypeError: argument of type 'float' is not iterable
因为其中一行中的 NaN
。所以我尝试了这种语法-
df["B"][["4" in a for a in df["A"].str.split(',') if pd.notnull(a)]]
但是我得到了 ValueError: The truth value of an array with more than one element is ambiguous。使用 a.any() 或 a.all()
。
知道如何让它发挥作用吗?我尝试了一些想法,但没有一个奏效,而且我真的不知道为什么这种语法是错误的。
预期输出 - 7
。
最佳答案
使用 pandas 替代品:
s = df.loc[df["A"].str.split(',', expand=True).eq('4').any(axis=1), 'B']
print (s)
1 7
Name: B, dtype: int64
解释:
在Series.str.split
中通过参数expand=True
创建DataFrame :
print (df["A"].str.split(',', expand=True))
0 1 2
0 1 2 3
1 4 5 6
2 NaN NaN NaN
3 8 None None
通过 DataFrame.eq
进行比较(==
):
print (df["A"].str.split(',', expand=True).eq('4'))
0 1 2
0 False False False
1 True False False
2 False False False
3 False False False
通过 DataFrame.any
检查每行是否至少有一个 True
:
print (df["A"].str.split(',', expand=True).eq('4').any(axis=1))
0 False
1 True
2 False
3 False
dtype: bool
最后按 DataFrame.loc
过滤与 boolean indexing
.
您的解决方案应更改为 if-else
和 isinstance
:
mask = ["4" in a if isinstance(a, list) else False for a in df["A"].str.split(',')]
s = df.loc[mask, 'B']
关于python - 在非空行上过滤数据框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55688633/
我想用 python 读取串行端口,并用 readline 打印结果,但我在所有结果行之间得到空行。你能告诉我如何删除所有空行吗? 我的代码: #!/usr/bin/python import ser
我正在编写一个程序,该程序存储用户输入的数字,但如果输入空白则退出。 我尝试将其设为字符数组并检查长度。如果长度大于0,则表示有输入,因此它将存储输入。如果长度为0,则表示没有输入,因此退出循环。 d
这个项目要求我通过取出所有注释、空行、额外的空格和括号中的信息来读取处理中的文件,然后将其打印到output.txt中。我在处理数据和删除所有注释、空行、额外的空格和括号中的信息时遇到了麻烦。 这是我
有没有办法从服务器响应中删除空行?我已经尝试过: trimSpaces true 和 这没有正确解决问题,因为在 init param 方法中它甚至删除了
你好, if('\t' == input [0] ||'\v' == input [0] ||'\r' == input [0] ||'\n' == input [0] || '\0' == in
我不知道如何用语言来解释这个场景。所以我在写例子: 我有一个名为 tblType 的表: type_id | type_name --------------------- 1 |
代码如下: <?php /* *读取文件内容至字符串中,同时去除换行、行首行尾空格。 */ header("Content-type: text/html; chars
我正在将行与两个文本文件的行进行比较,ref.txt (引用)和 log.txt .但是我想忽略任一文件中的任意数量的空行;我怎样才能做到这一点? ref.txt one two three end
关于删除jtable中未使用的行的问题我正在使用DefualtTableModel我的表已经有一些数据并且当我更新它时将一些列留空以稍后更新主题,以便它们是空列..我想在保存数据之前用按钮删除主题..
我看到列表,它有适量的行(根据 QStringList 中的元素数量),但行是空的。 我做错了什么? 在 C++ 中我的代码是: QStringList s; s.append("1"); s.app
我怎样才能从这些行中隐藏 UITableView 的行,什么是不使用的。例如,看截图: 我可以只显示 4 行并隐藏其他未使用的行吗?所以,我只显示 4 行,然后是白屏,而不是现在的行 最佳答案 喜欢将
对于我的 bash/html 中的 CGI,我有这个脚本(只是 awk 脚本,其余代码只是一个简单的 hmtl 代码): for fn in /var/www/cgi-bin/LPAR_MAP/*;
一直在尝试使用输出 html 方法转换 xml 文档,以便使用 xsl 样式表(使用 CSS)在浏览器中显示。想显示以下代码 Source A Co
我想在我的 LOG 语句之后添加一个空行,以使我的日志更加分隔和可读。 我该怎么做? 当前声明: LOGGER.info("Person's name is {} .", person.getNa
我正在执行以下假脱机语句: SET VERIFY OFF SET FEEDBACK OFF SET HEADING OFF SET TRIMSPOOL ON SET TERM OFF SPOOL &p
包含五个相关字段的表格; ID (Autoincrement,unique, etc) ID_customer - ties in each row to another table with cus
我有这样的风格: #cytoscape-container { width: 100%; height: 100%; margin: 0 aut
while((fscanf(datafile, " %127[^;] %[^\n]", name, movie)) == 2) { printf("%s\n", movi
我有这个two commands获取 SID 用户帐户 wmic useraccount where name='%username%' get sid | findstr /b /C:"S-1" >
我使用这段代码: window.removeDuplicateLines = function() { "use strict"; var bodyText = $('#text-area')
我是一名优秀的程序员,十分优秀!