- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在处理一个用 Pandas 读取的大型 CSV 文件。其中一列(不是索引)是时间戳数据,如下所示:
sent>23:56:51.748912
有前缀 sent>
后跟小时、分钟、秒、微秒。我想修改所有这些时间戳条目,以便时间向后移动 11 小时。所以上面的例子看起来像这样:
sent>12:56:51.748912
我期待/希望有一些足够智能的模算术,以便将 sent>09:02:13.245511
的条目向后移动 11 将变成 sent>22 :02:13.245511
。
我遇到了一些困难,因为 NumPy datetime64
和 Pandas TimeSeries
想要完整的年、月、日,但我没有。到目前为止我看到的文档和示例都相当简洁。我尝试过将数据存储在各种不同的结构中(总结如下),但到目前为止似乎没有任何效果。
(仍在学习 numpy/pandas...请对我放轻松...)这是我尝试过的:
import pandas as pd
import numpy as np
import datetime
df = pd.read_csv(filename, header=None, delimiter=' ', skiprows=2,
skipfooter=2, names=colnames, index_col=False, engine='python')
senttime_col = np.array(df['sent_time'], dtype='str')
senttime_col = np.char.lstrip(senttime_col, 'sent>')
# this creates np array of strings with elements like: 23:56:51.748585
senttimes_ts = pd.to_datetime(df['sent_time'])
# this creates TimeSeries with elements like: sent>23:56:51.748585
senttimes_ts.tshift(pd.Timedelta('-11 hours'))
# ValueError: Freq was not given and was not set in the index
senttimes_df = pd.DataFrame(senttime_col, index=None)
senttimes_df.shift(periods=-11, freq=pd.Timedelta(hours=1))
# TypeError: unsupported operand type(s) for +: 'numpy.int64' and 'Timedelta'
senttimes = np.datetime64(senttime_col)
# ValueError: Could not convert object to NumPy datetime
senttimes = np.datetime64(senttime_col, 'h:m:s.us')
# TypeError: Invalid datetime unit "h:m:s.us" in metadata
senttimes = np.array(senttime_col, dtype='datetime64[us]')
# ValueError: Error parsing datetime string "00:16:51.748269" at position 2
timelist = [datetime.datetime.strptime(x, '%H:%M:%S.%f') for x in senttime_col]
# ValueError: time data 'None' does not match format '%H:%M:%S.%f'
最佳答案
假设,s
是您的系列专栏:
s = pd.Series(['sent>12:56:51.748912'] * 10000)
# this removes the 'sent>' string from the beginning
s = s.str[5:]
我将使用此函数来查找我已经解析的日期 -
def lookup2(s):
'''uses .map() to apply changes'''
dates = {date:pd.to_datetime(date) - pd.Timedelta('11 hours') for date in s.unique()}
return s.map(dates)
然后,我们将结果保存回s
。注意:我没有遇到这个问题 - “我遇到了一些困难,因为 NumPy datetime64 和 Pandas TimeSeries 都需要完整的年、月和日,但我没有这些。”
s = lookup2(s)
In [156]: s.head()
Out[156]:
0 2015-05-10 12:56:51.748912
1 2015-05-10 12:56:51.748912
2 2015-05-10 12:56:51.748912
3 2015-05-10 12:56:51.748912
4 2015-05-10 12:56:51.748912
dtype: datetime64[ns]
将时间拨回 11 小时 -
In [154]: t = (s - pd.Timedelta('11 hours')).dt.time
In [155]: t.head()
Out[155]:
0 23:56:51.748912
1 23:56:51.748912
2 23:56:51.748912
3 23:56:51.748912
4 23:56:51.748912
dtype: object
请告诉我这是否适合您。
关于python - 对不带年、月、日的时间戳数组进行算术,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30147337/
我正在尝试从 1 循环到 12,并为应用中特定 View 的更改网格输出一些跨度宽度。 $span-width: 8.21875%; $gap: 0.125%; @for $i from 1 thro
我试图在 Jekyll 的液体模板引擎中做一些基本的算术。我已经分配了一个变量 numColumns我试图在条件语句中使用它。 {% assign numColumns = 3 %} 注意我在下面的表
与 shift_left ieee.numeric_std 的功能, 我想将信号左移并插入 1或 0从右边。 signal qo: signed (3 downto 0) := (others=>'0
您在控制台中输入一些内容,例如(8+8)。然后程序会告诉你括号的插入是否正确。 这是我对错误括号的定义(当然还没有完成): () this means if one array element is
我有两个表(使用 PostgreSQL),它们看起来如下: 表1(p点从1到450递增1) --------+-------+--------+---------+---------+-------+
我正在编写一个任意精度的有理数包,我需要测试它的正确性和效率。当然,我可以自己组合一组临时测试,但由于我远不是第一个这样做的人,所以我认为值得一问:任何人都可以推荐我可以使用的现有测试集吗? 编辑:我
我最近一直在使用和学习 CSS3,并享受它的许多功能。现在我想知道是否可以设置一个有条件地分配 block 元素宽度的 CSS 规则。我所追求的那种东西 - 如果屏幕宽度小于 500 像素,则使用 3
我对这个实验中h的值有点疑惑。在 cpp 中, int h,J=3,n=200,p=3,h_m=(n+p+1)/2; float rt=(float)h_m/n; for(int j=0,j
算术+和按位或有什么区别吗?这有什么不同。 uint a = 10; uint b = 20; uint arithmeticresult = a + b; uint bitwiseOR = a |
我一直在尝试让算术 if 运算符起作用,但我似乎做不到。我是 C++ 的新手,仍在学习基础知识,但我只是想知道我是否正确使用了这个运算符。如果 x using namespace std; int
我在 VC++2010 中做过一些混合不同大小的操作数导致添加操作溢出的测试: int _tmain(int argc, _TCHAR* argv[]) { __int8 a=127;
#include int main(int argc,char *argv[]) { int i=10; void *k; k=&i; k++; printf("%p\n
在过去的 5 个小时里,我一直在寻找答案。尽管我找到了很多答案,但它们并没有以任何方式提供帮助。 我基本上要寻找的是任何 32 位无符号整数的按位异或运算符的数学、算术唯一表示。 尽管这听起来很简单,
结果是 127 double middle = 255 / 2 虽然这产生了 127.5 Double middle = 255 / 2 同时这也会产生 127.5 double middle = (
我在 Java 1.7 中有以下代码: DateFormat df = DateFormat.getInstance(); Date startDate = df.parse("07/28/12 01
此查询有效,没有错误 select add_months(date '2011-01-31', 1) from dual; ,而这个: select date '2011-01-31' + inter
理论上来说,如果我有一个无序项目列表 Link1 Link1 我如何使用 jQuery 执行以下操作? 1) 找到每个单独a元素的宽度 2) 找到每个单独的 li 元素的宽度 3)
想法如下:假设我有一个列表 P = [(1,0),(4,3)] 或类似的列表。我想以以下方式计算此列表定义的多项式:1X^0 + 4X^3。 为此,我编写了以下内容: evaluate(P,X,Y)
我正在从 mysql 数据库中提取数据。我想添加多次运行的长度,并按照跑得最远的人的排名对它们进行排序。 function determineLength($db, $name){
当尝试执行一个简单的 bash 脚本以将前面带有 0 的数字递增 1 时,原始数字被错误地解释。 #!/bin/bash number=0026 echo $number echo $((number
我是一名优秀的程序员,十分优秀!