- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有两个数据框:
数据框一有一个时间戳、一个因素(发电量)和一个位置。
数据框二有一个事件(降雨量)、事件开始时间的时间戳、事件结束时间的时间戳和位置。
我想在第一个数据框中包含一列,表示当产生一定电量时的降雨量。
我能够创建一个小型数据框并使用以下代码运行测试:
df1 =pd.DataFrame({'factor': ['2','3','4','5','6','7'],
'timestamp':['2022-12-01 10:00:00','2022-12-01 10:05:00',
'2022-12-01 10:15:00','2022-12-01 10:20:00',
'2022-12-15 13:00:00','2022-12-20 06:00:00'],
'location':['a','b','c','d','a','d']
})
df2 =pd.DataFrame({'event': ['2','3','4','5','6','7'],
'time_start':['2022-12-01 9:00:00','2022-12-02 10:05:00',
'2022-12-01 8:15:00','2022-12-01 9:20:00',
'2022-12-25 10:00:00','2022-12-20 05:00:00'],
'time_end':['2022-12-01 16:00:00','2022-12-02 10:15:00',
'2022-12-01 20:15:00','2022-12-01 20:20:00',
'2022-12-25 13:00:00','2022-12-20 06:30:00'],
'location':['a','b','c','d','b','c']
})
df1['timestamp'] = pd.to_datetime(df1['timestamp'])
df2['time_start'] = pd.to_datetime(df2['time_start'])
df2['time_end'] = pd.to_datetime(df2['time_end'])
df3 = df1.merge(df2, how='outer', on="location")
df3['quantity_rain'] = df3['event'].where(df3['timestamp'].between(df3['time_start'], df3['time_end']))
df3.replace(np. nan,0)
但是当我使用较大的数据帧运行代码时,内核会重新启动,因为我使用了太多的内存。
当我尝试使用 df3 = df1.merge(df2, how='outer', on="location")
我试图找到解决这个问题的方法,我读到我应该尝试使用 SQL。我想我可以合并数据帧,将合并的数据帧转换回 pandas,然后照常进行,但我不确定该怎么做(或者即使这是处理事情的最佳方式?)。当我运行我的代码时出现错误* sqlite://(sqlite3.OperationalError) 没有这样的表:df1
我的代码如下:
%load_ext sql
%sql sqlite://
import sqlite3
conn = sqlite3.connect('test_database')
c = conn.cursor()
# Converting dataframes to SQL tables
df1.to_sql('df1_SQL', conn, if_exists='replace', index = False)
df2.to_sql('df1_SQL', conn, if_exists='replace', index = False)
# Merging tables
%sql SELECT * FROM df1 JOIN df2 USING (location)
有没有办法用更少的 ram 和 python 来做到这一点?如果不是,sql 是可行的方法吗?我该如何修复我的代码?
最佳答案
要克服内存溢出问题,这里有一个方法。
从 df2
的开始和结束列创建一个间隔索引,然后通过将 df2
的索引设置为 location
以及区间指数。现在按 location
对 df1
进行分组,最后使用映射系列 map
将 timestamp
值映射到相应的事件 concat
所有组在一起
ix = pd.IntervalIndex.from_arrays(df2['time_start'], df2['time_end'], closed='both')
event = df2.set_index(['location', ix])['event']
pd.concat([
g.assign(event=g['timestamp'].map(event.loc[k]))
for k, g in df1.groupby('location', sort=False)
])
在 concat
之后,结果将是
factor timestamp location event
0 2 2022-12-01 10:00:00 a 2
4 6 2022-12-15 13:00:00 a NaN
1 3 2022-12-01 10:05:00 b NaN
2 4 2022-12-01 10:15:00 c 4
3 5 2022-12-01 10:20:00 d 5
5 7 2022-12-20 06:00:00 d NaN
关于python - 有效地识别发生在开始和结束时间戳之间的事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74858392/
我收到未知数据,我想以编程方式查看相关性,并将所有完全相关的变量组合在一起(忽略方向)。在下面的数据集中,我可以手动查看相关性并说 a, f, g, h一起去吧b, d, e .我怎样才能以编程方
这个问题在这里已经有了答案: use dplyr's summarise_each to return one row per function? (3 个答案) 关闭 4 年前。 作为探索性工作的
我想要完成的是使用数组存储未知大小的多项式。我在互联网上看到的是使用一个数组,每个单元格都包含系数,度数是单元格编号,但这不是有效的,因为如果我们有一个多项式,如:6x^14+x+5。这意味着我们将从
嘿伙计们,我一直在尝试解析 HTML 文件以从中抓取文本,但时不时地,我会得到一些非常奇怪的字符,例如 à€œ。我确定是“智能引号”或弯头标点符号导致了我的所有问题,因此我的临时修复是搜索所有这些字符
我原来的 data.table 由三列组成。 site、observation_number 和 id。 例如以下是 id = z 的所有观察结果 |site|observation_number|i
"Premature optimisation is the root of all evil (but it's nice to have once you have an ugly solutio
给定这个数组 X: [1 2 3 2 3 1 4 5 7 1] 和行长度数组R: [3 2 5] 表示转换后每行的长度。 我正在寻找一个计算效率高的函数来将 X reshape 为数组 Y: [[ 1
我有一些 data.frame s: # Sample data a <- data.frame(c(1:10), c(11:20)) names(a) <- c("A", "B") b <- dat
我有点困惑。列表擅长任意位置插入,但不善于随机访问? (怎么可能)如果你不能随机访问,你怎么知道在哪里插入? 同样,如果你可以在任何位置插入,为什么你不能从那个位置高效地读取? 最佳答案 如果您已经有
我有一个向量,我想计算它的移动平均值(使用宽度为 5 的窗口)。 例如,如果有问题的向量是[1,2,3,4,5,6,7,8],那么 结果向量的第一个条目应该是 [1,2,3,4,5] 中所有条目的总和
有一个随机整数生成器,它生成随机整数并在后台运行。需求设计一个API,调用时返回当时的簇数。 簇:簇是连续整数的字典顺序。例如,在这种情况下,10,7,1,2,8,5,9 簇是 3 (1,2--5--
我想做的是将一组 (n) 项分成大小相等的组(大小为 m 的组,并且为简单起见,假设没有剩余,即 n 可以被 m 整除)。这样做多次,我想确保同一组中的任何项目都不会出现两次。 为了使这稍微更具体一些
假设我有一些包含类型排列的模板表达式,在本例中它们来自 Abstract Syntax Tree : template
我已经在这方面工作了几天,似乎没有我需要的答案。 由于担心这个被标记为重复,我将解释为什么其他问题对我不起作用。 使用 DIFFLIB for Python 的任何答案都无助于我的需求。 (我在下面描
我正在使用 NumPy 数组。 我有一个 2N 长度向量 D,并希望将其一部分 reshape 为 N x N 数组 C. 现在这段代码可以满足我的要求,但对于较大的 N 来说是一个瓶颈: ``` i
我有一个问题: 让我们考虑这样的 pandas 数据框: Width Height Bitmap 67 56 59 71 61 73 ...
我目前正在用 C 语言编写一个解析器,设计它时我需要的东西之一是一个可变字符串“类”(一组对表示实例的不透明结构进行操作的函数),我将其称为 my_string。 string 类的实例只不过是包装
假设我在 --pandas-- 数据框中有以下列: x 1 589 2 354 3 692 4 474 5 739 6 731 7 259 8 723
我有一个成员函数,它接受另一个对象的常量引用参数。我想 const_cast 这个参数以便在成员函数中轻松使用它。为此,以下哪个代码更好?: void AClass::AMember(const BC
我们目前正在将 Guava 用于其不可变集合,但我惊讶地发现他们的 map 没有方法可以轻松创建只需稍作修改的新 map 。最重要的是,他们的构建器不允许为键分配新值或删除键。 因此,如果我只想修改一
我是一名优秀的程序员,十分优秀!