- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Anaconda Jupyter Notebook 和 Python 3 重新创建 DataCamp 练习。该练习是导入 csv 文件,使用在 lambda 函数内使用 .replace() 方法删除“total_dollar”列中的美元符号。然后在另一个新列中再次执行相同的操作,但这次使用 RegEx.findall()。我遇到麻烦的地方是使用 [0] 对 re.findall() 列表进行切片以获取值。 DataCamp 指令说: 请注意,因为 re.findall() 返回一个列表,所以您必须对其进行切片才能访问实际值。
以下代码在他们的网站上给了我正确的答案,但在 Jupyter Notebook 中却没有。
tips2 = pd.read_csv('c:\\datacamp\\data\\tips2.csv')
print(tips2.head())
# Write the lambda function using replace
tips2['total_dollar_replace'] = tips2.total_dollar.apply(lambda x: x.replace('$', ''))
# Write the lambda function using regular expressions
tips2['total_dollar_re'] = tips2.total_dollar.apply(lambda x: re.findall('\d+\.\d+', x)[0])
# Print the head of tips
print(tips2.head())
输出如下:
total_bill tip sex smoker day time size total_dollar
0 16.99 1.01 Female No Sun Dinner 2.0 $16.99
1 10.34 1.66 Male No Sun Dinner 3.0 $10.34
2 21.01 3.50 Male No Sun Dinner 3.0 $21.01
3 23.68 3.31 Male No Sun Dinner 2.0 $23.68
4 24.59 3.61 Female No Sun Dinner 4.0 $24.59
---------------------------------------------------------------------------
IndexError Traceback (most recent call last)
<ipython-input-152-598533768fa6> in <module>
28
29 # Write the lambda function using regular expressions
---> 30 tips2['total_dollar_re'] = tips2.total_dollar.apply(lambda x: re.findall('\d+\.\d+', x)[0])
31
32
C:\conda\envs\datacamp\lib\site-packages\pandas\core\series.py in apply(self, func, convert_dtype, args, **kwds)
4036 else:
4037 values = self.astype(object).values
-> 4038 mapped = lib.map_infer(values, f, convert=convert_dtype)
4039
4040 if len(mapped) and isinstance(mapped[0], Series):
pandas\_libs\lib.pyx in pandas._libs.lib.map_infer()
<ipython-input-152-598533768fa6> in <lambda>(x)
28
29 # Write the lambda function using regular expressions
---> 30 tips2['total_dollar_re'] = tips2.total_dollar.apply(lambda x: re.findall('\d+\.\d+', x)[0])
31
32
IndexError: list index out of range
去掉索引切片器,输出会更好,但不完全是它应该的样子:
total_bill tip sex smoker day time size total_dollar \
0 16.99 1.01 Female No Sun Dinner 2.0 $16.99
1 10.34 1.66 Male No Sun Dinner 3.0 $10.34
2 21.01 3.50 Male No Sun Dinner 3.0 $21.01
3 23.68 3.31 Male No Sun Dinner 2.0 $23.68
4 24.59 3.61 Female No Sun Dinner 4.0 $24.59
total_dollar_replace total_dollar_re
0 16.99 [16.99]
1 10.34 [10.34]
2 21.01 [21.01]
3 23.68 [23.68]
4 24.59 [24.59]
最后一列不应该是一个列表,这应该是使用 [0] 切片器的目的。非常感谢您帮助我了解我所缺少的内容。
最佳答案
IndexError
似乎是由正则表达式返回不匹配的一行或多行引起的。或者换句话说,re.findall() 返回长度为 0 的列表,并且您无法索引到空列表。如果您愿意放弃 lambda 函数而选择完整的函数并编写如下内容,则可以解决此问题:
def my_regex_fun(x):
try:
return re.findall('\d+\.\d+', x)[0]
except IndexError:
return None # Return your choice of whatever here. np.NaN might be a good option
tips2['total_dollar_re'] = tips2.total_dollar.apply(my_regex_fun)
这将解决 IndexError
问题,但不会解决任何其他可能出现的问题。
关于python - 对 findall() 列表进行切片以获取值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59014055/
我喜欢 smartcase,也喜欢 * 和 # 搜索命令。但我更希望 * 和 # 搜索命令区分大小写,而/和 ?搜索命令遵循 smartcase 启发式。 是否有隐藏在某个地方我还没有找到的设置?我宁
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题? Update the question所以它是on-topic对于堆栈溢出。 10年前关闭。 Improve this qu
从以下网站,我找到了执行java AD身份验证的代码。 http://java2db.com/jndi-ldap-programming/solution-to-sslhandshakeexcepti
似乎 melt 会使用 id 列和堆叠的测量变量 reshape 您的数据框,然后通过转换让您执行聚合。 ddply,从 plyr 包看起来非常相似..你给它一个数据框,几个用于分组的列变量和一个聚合
我的问题是关于 memcached。 Facebook 使用 memcached 作为其结构化数据的缓存,以减少用户的延迟。他们在 Linux 上使用 UDP 优化了 memcached 的性能。 h
在 Camel route ,我正在使用 exec 组件通过 grep 进行 curl ,但使用 ${HOSTNAME} 的 grep 无法正常工作,下面是我的 Camel 路线。请在这方面寻求帮助。
我正在尝试执行相当复杂的查询,在其中我可以排除与特定条件集匹配的项目。这是一个 super 简化的模型来解释我的困境: class Thing(models.Model) user = mod
我正在尝试执行相当复杂的查询,我可以在其中排除符合特定条件集的项目。这里有一个 super 简化的模型来解释我的困境: class Thing(models.Model) user = mod
我发现了很多嵌入/内容项目的旧方法,并且我遵循了在这里找到的最新方法(我假设):https://blog.angular-university.io/angular-ng-content/ 我正在尝试
我正在寻找如何使用 fastify-nextjs 启动 fastify-cli 的建议 我曾尝试将代码简单地添加到建议的位置,但它不起作用。 'use strict' const path = req
我正在尝试将振幅 js 与 React 和 Gatsby 集成。做 gatsby developer 时一切看起来都不错,因为它发生在浏览器中,但是当我尝试 gatsby build 时,我收到以下错
我试图避免过度执行空值检查,但同时我想在需要使代码健壮的时候进行空值检查。但有时我觉得它开始变得如此防御,因为我没有实现 API。然后我避免了一些空检查,但是当我开始单元测试时,它开始总是等待运行时异
尝试进行包含一些 NOT 的 Kibana 搜索,但获得包含 NOT 的结果,因此猜测我的语法不正确: "chocolate" AND "milk" AND NOT "cow" AND NOT "tr
我正在使用开源代码共享包在 iOS 中进行 facebook 集成,但收到错误“FT_Load_Glyph failed: glyph 65535: error 6”。我在另一台 mac 机器上尝试了
我正在尝试估计一个标准的 tobit 模型,该模型被审查为零。 变量是 因变量 : 幸福 自变量 : 城市(芝加哥,纽约), 性别(男,女), 就业(0=失业,1=就业), 工作类型(失业,蓝色,白色
我有一个像这样的项目布局 样本/ 一种/ 源/ 主要的/ java / java 资源/ .jpg 乙/ 源/ 主要的/ java / B.java 资源/ B.jpg 构建.gradle 设置.gr
如何循环遍历数组中的多个属性以及如何使用map函数将数组中的多个属性显示到网页 import React, { Component } from 'react'; import './App.css'
我有一个 JavaScript 函数,它进行 AJAX 调用以返回一些数据,该调用是在选择列表更改事件上触发的。 我尝试了多种方法来在等待时显示加载程序,因为它当前暂停了选择列表,从客户的 Angul
可能以前问过,但找不到。 我正在用以下形式写很多语句: if (bar.getFoo() != null) { this.foo = bar.getFoo(); } 我想到了三元运算符,但我认
我有一个表单,在将其发送到 PHP 之前我正在执行一些验证 JavaScript,验证后的 JavaScript 函数会发布用户在 中输入的文本。页面底部的标签;然而,此消息显示短暂,然后消失...
我是一名优秀的程序员,十分优秀!