- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我先说两件事:
我正在努力将一个项目从 R 移植到 python,并且正在努力寻找一种转换文本到 float 转换过程的好方法。具体来说,我是:
error='coerce'
选项强制从文本强制转换为 float 如何让 pandas 将浮点值的文本表示干净利落地转换为相应的 float ?
我遇到的问题是数值精度。例如:
In[1]: pd.to_numeric('3.785', errors='coerce')
Out[2]: 3.7850000000000001
我明白为什么会这样(即 3.785 的表示方式不容易在底层二进制表示中表示)。我想弄清楚的是,是否有一种方法可以解决它高效发生的原因。
例如,在 R 中,幕后发生了很多事情,但在 as.numeric API 中,您得到的数字表面上由文本值表示:
> as.numeric('3.785')
[1] 3.785
这是我想要的行为。这可能使用 Pandas / python 吗?我愿意合并其他软件包,或者被告知“那是不可能的”。
最佳答案
我不确定您是在问更多关于精度还是精度显示(格式)的问题,但希望这个答案能解决这两个问题。
在幕后,r 和 pandas 可能在做完全相同的事情,但默认显示让它看起来不同。例如,如果您想更好地了解 r 如何存储数字,您可以这样做:
> sprintf( "%.20f", as.numeric('3.785') )
[1] "3.78500000000000014211"
当然,一旦您超过了小数点后第 14 位左右,您就超出了 double float 中可以存储的内容,这些数字实际上没有意义。尽管如此,这至少应该足以表明 r 并没有真正将其存储为完全 3.785
。
诚然,有比某处更严格的答案,但实际上“忽略小数点后第 13 位或第 14 位的任何内容”对于标准数据工作几乎总是足够的(而且你几乎肯定最好花钱你的时间在别处,而不是担心小数点后第 14 位)。
我不能确切地说出为什么你使用的 pandas 函数显示 3.7850000000000001
而不是 3.785
但一般来说你可以在不同的部分获得不同级别的默认显示精度numpy 和 Pandas 。例如,如果您只是将 [
和 ]
放在您的数字周围(以传递列表而不是标量),pd.to_numeric
将具有输出一个 numpy 数组,并显示更少的小数位:
In [61]: pd.to_numeric(['3.785'], errors='coerce')
Out[61]: array([ 3.785])
如果您传递的是系列而不是列表,您也会得到类似的显示输出。如果您想要特定级别的显示精度,只需明确指定即可:
In [62]: pd.to_numeric(pd.Series(['3.785']), errors='coerce').map('{:,.20f}'.format)
Out[62]:
0 3.78500000000000014211
因此,当您明确显示 20 位小数时,您会在 r 和 pandas/numpy 中看到相同的数字表示。
也许值得一提的是 python 确实提供了一个 Decimal type它具有精确的小数点(不同于单精度或 double float ),但很少将其用于数据科学或数值应用,因为它不是原生的 pandas 类型,而且性能通常会很差。我相信它主要用于会计应用程序。
关于python - Pandas to_numeric 数值精度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48547017/
pandas.crosstab 和 Pandas 数据透视表似乎都提供了完全相同的功能。有什么不同吗? 最佳答案 pivot_table没有 normalize争论,不幸的是。 在 crosstab
我能找到的最接近的答案似乎太复杂:How I can create an interval column in pandas? 如果我有一个如下所示的 pandas 数据框: +-------+ |
这是我用来将某一行的一列值移动到同一行的另一列的当前代码: #Move 2014/15 column ValB to column ValA df.loc[(df.Survey_year == 201
我有一个以下格式的 Pandas 数据框: df = pd.DataFrame({'a' : [0,1,2,3,4,5,6], 'b' : [-0.5, 0.0, 1.0, 1.2, 1.4,
所以我有这两个数据框,我想得到一个新的数据框,它由两个数据框的行的克罗内克积组成。正确的做法是什么? 举个例子:数据框1 c1 c2 0 10 100 1 11 110 2 12
TL;DR:在 pandas 中,如何绘制条形图以使其 x 轴刻度标签看起来像折线图? 我制作了一个间隔均匀的时间序列(每天一个项目),并且可以像这样很好地绘制它: intensity[350:450
我有以下两个时间列,“Time1”和“Time2”。我必须计算 Pandas 中的“差异”列,即 (Time2-Time1): Time1 Time2
从这个 df 去的正确方法是什么: >>> df=pd.DataFrame({'a':['jeff','bob','jill'], 'b':['bob','jeff','mike']}) >>> df
我想按周从 Pandas 框架中的列中累积计算唯一值。例如,假设我有这样的数据: df = pd.DataFrame({'user_id':[1,1,1,2,2,2],'week':[1,1,2,1,
数据透视表的表示形式看起来不像我在寻找的东西,更具体地说,结果行的顺序。 我不知道如何以正确的方式进行更改。 df示例: test_df = pd.DataFrame({'name':['name_1
我有一个数据框,如下所示。 Category Actual Predicted 1 1 1 1 0
我有一个 df,如下所示。 df: ID open_date limit 1 2020-06-03 100 1 2020-06-23 500
我有一个 df ,其中包含与唯一值关联的各种字符串。对于这些唯一值,我想删除不等于单独列表的行,最后一行除外。 下面使用 Label 中的各种字符串值与 Item 相关联.所以对于每个唯一的 Item
考虑以下具有相同名称的列的数据框(显然,这确实发生了,目前我有一个像这样的数据集!:() >>> df = pd.DataFrame({"a":range(10,15),"b":range(5,10)
我在 Pandas 中有一个 DF,它看起来像: Letters Numbers A 1 A 3 A 2 A 1 B 1 B 2
如何减去两列之间的时间并将其转换为分钟 Date Time Ordered Time Delivered 0 1/11/19 9:25:00 am 10:58:00 am
我试图理解 pandas 中的下/上百分位数计算,但有点困惑。这是它的示例代码和输出。 test = pd.Series([7, 15, 36, 39, 40, 41]) test.describe(
我有一个多索引数据框,如下所示: TQ bought HT Detailed Instru
我需要从包含值“低”,“中”或“高”的数据框列创建直方图。当我尝试执行通常的df.column.hist()时,出现以下错误。 ex3.Severity.value_counts() Out[85]:
我试图根据另一列的长度对一列进行子串,但结果集是 NaN .我究竟做错了什么? import pandas as pd df = pd.DataFrame([['abcdefghi','xyz'],
我是一名优秀的程序员,十分优秀!