【发布时间】:2019-11-27 13:54:42
【问题描述】:
我需要根据给定时间拆分几个 csv 文件。在这些文件中,时间值以秒为单位并在“时间”列中给出。
例如,如果我想在 0.1 秒内拆分 aaa.csv 文件,则需要将时间为 0.0 到 0.1 的第一组行(附件中没有 1 到 8)写入 aaa1.csv,然后时间大于 0.1 到 0.2 的行(附件中的第 9 到 21 号)到aaa2.csv 等等...(基本上是给定时间的倍数)。
输出文件需要与输入文件同名,并在末尾加上一个数字。并且输出文件需要写入不同的位置/文件夹。 时间值需要是一个变量。所以一次我可以在 0.1 秒内拆分文件,另一次我可以在 0.7 秒内拆分文件,依此类推。
请问我该如何为此编写一个 python 脚本?文件如下(整个119K文件可以从https://fil.email/vnsZsp7b下载):
No.,Time,Length
1,0,146
2,0.006752,116
3,0.019767,156
4,0.039635,144
5,0.06009,147
6,0.069165,138
7,0.0797,133
8,0.099397,135
9,0.120142,135
10,0.139721,148
11,0.1401,126
12,0.1401,120
13,0.140101,123
14,0.140101,120
15,0.141294,118
16,0.141295,118
17,0.141295,114
18,0.144909,118
19,0.160639,119
20,0.161214,152
21,0.185625,143
... etc
在@Serafeim 的回答之后,我尝试了这个:
import pandas as pd
import numpy as np
import glob
import os
path = '/root/Desktop/TT1/'
mystep = 0.4
for filename in glob(os.path.join(path, '*.csv')):
df = pd.read_csv(filename)
def data_splitter(df):
max_time = df['Time'].max() # get max value of Time for the current csv file (df)
myrange= np.arange(0, max_time, mystep) # build the threshold range
for k in range(len(myrange)):
# build the upper values
temp = df[(df['Time'] >= myrange[k]) & (df['Time'] < myrange[k] + mystep)]
#temp.to_csv("/root/Desktop/T1/xx_{}.csv".format(k))
temp.to_csv("/root/Desktop/T1/{}_{}.csv".format(filename, k))
data_splitter(df)
【问题讨论】:
-
到目前为止你有什么尝试?
-
@MarsNebulaSoup 我知道如何使用wireshark 中的editcap 工具来做到这一点。但它不支持小于 1 秒的值。我是编程新手,所以我不知道该怎么做。我真的很抱歉
-
@Hasa 但您是否尝试过将
0.1传递给editcap? -
是的。它不接受十进制值。
-
@Hasa 从 4 天前就开始了,如果你想尝试从 git 编译更新的版本。 github.com/wireshark/wireshark/commit/…
标签: python python-3.x pandas csv