forked from pandas-dev/pandas
-
Notifications
You must be signed in to change notification settings - Fork 2
/
parser_vb.py
121 lines (90 loc) · 4.68 KB
/
parser_vb.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
from .pandas_vb_common import *
import os
from pandas import read_csv
try:
from cStringIO import StringIO
except ImportError:
from io import StringIO
class read_csv1(object):
goal_time = 0.2
def setup(self):
self.N = 10000
self.K = 8
self.df = DataFrame((np.random.randn(self.N, self.K) * np.random.randint(100, 10000, (self.N, self.K))))
self.df.to_csv('test.csv', sep='|')
self.format = (lambda x: '{:,}'.format(x))
self.df2 = self.df.applymap(self.format)
self.df2.to_csv('test2.csv', sep='|')
def time_sep(self):
read_csv('test.csv', sep='|')
def time_thousands(self):
read_csv('test.csv', sep='|', thousands=',')
def teardown(self):
os.remove('test.csv')
os.remove('test2.csv')
class read_csv2(object):
goal_time = 0.2
def setup(self):
self.data = ['A,B,C']
self.data = (self.data + (['1,2,3 # comment'] * 100000))
self.data = '\n'.join(self.data)
def time_comment(self):
read_csv(StringIO(self.data), comment='#')
class read_csv3(object):
goal_time = 0.2
def setup(self):
self.data = """0.1213700904466425978256438611,0.0525708283766902484401839501,0.4174092731488769913994474336\n
0.4096341697147408700274695547,0.1587830198973579909349496119,0.1292545832485494372576795285\n
0.8323255650024565799327547210,0.9694902427379478160318626578,0.6295047811546814475747169126\n
0.4679375305798131323697930383,0.2963942381834381301075609371,0.5268936082160610157032465394\n
0.6685382761849776311890991564,0.6721207066140679753374342908,0.6519975277021627935170045020\n"""
self.data2 = self.data.replace(',', ';').replace('.', ',')
self.data = (self.data * 200)
self.data2 = (self.data2 * 200)
def time_default_converter(self):
read_csv(StringIO(self.data), sep=',', header=None,
float_precision=None)
def time_default_converter_with_decimal(self):
read_csv(StringIO(self.data2), sep=';', header=None,
float_precision=None, decimal=',')
def time_default_converter_python_engine(self):
read_csv(StringIO(self.data), sep=',', header=None,
float_precision=None, engine='python')
def time_default_converter_with_decimal_python_engine(self):
read_csv(StringIO(self.data2), sep=';', header=None,
float_precision=None, decimal=',', engine='python')
def time_precise_converter(self):
read_csv(StringIO(self.data), sep=',', header=None,
float_precision='high')
def time_roundtrip_converter(self):
read_csv(StringIO(self.data), sep=',', header=None,
float_precision='round_trip')
class read_csv_categorical(object):
goal_time = 0.2
def setup(self):
N = 100000
group1 = ['aaaaaaaa', 'bbbbbbb', 'cccccccc', 'dddddddd', 'eeeeeeee']
df = DataFrame({'a': np.random.choice(group1, N).astype('object'),
'b': np.random.choice(group1, N).astype('object'),
'c': np.random.choice(group1, N).astype('object')})
df.to_csv('strings.csv', index=False)
def time_convert_post(self):
read_csv('strings.csv').apply(pd.Categorical)
def time_convert_direct(self):
read_csv('strings.csv', dtype='category')
def teardown(self):
os.remove('strings.csv')
class read_csv_dateparsing(object):
goal_time = 0.2
def setup(self):
self.N = 10000
self.K = 8
self.data = 'KORD,19990127, 19:00:00, 18:56:00, 0.8100, 2.8100, 7.2000, 0.0000, 280.0000\n KORD,19990127, 20:00:00, 19:56:00, 0.0100, 2.2100, 7.2000, 0.0000, 260.0000\n KORD,19990127, 21:00:00, 20:56:00, -0.5900, 2.2100, 5.7000, 0.0000, 280.0000\n KORD,19990127, 21:00:00, 21:18:00, -0.9900, 2.0100, 3.6000, 0.0000, 270.0000\n KORD,19990127, 22:00:00, 21:56:00, -0.5900, 1.7100, 5.1000, 0.0000, 290.0000\n '
self.data = (self.data * 200)
self.data2 = 'KORD,19990127 19:00:00, 18:56:00, 0.8100, 2.8100, 7.2000, 0.0000, 280.0000\n KORD,19990127 20:00:00, 19:56:00, 0.0100, 2.2100, 7.2000, 0.0000, 260.0000\n KORD,19990127 21:00:00, 20:56:00, -0.5900, 2.2100, 5.7000, 0.0000, 280.0000\n KORD,19990127 21:00:00, 21:18:00, -0.9900, 2.0100, 3.6000, 0.0000, 270.0000\n KORD,19990127 22:00:00, 21:56:00, -0.5900, 1.7100, 5.1000, 0.0000, 290.0000\n '
self.data2 = (self.data2 * 200)
def time_multiple_date(self):
read_csv(StringIO(self.data), sep=',', header=None,
parse_dates=[[1, 2], [1, 3]])
def time_baseline(self):
read_csv(StringIO(self.data2), sep=',', header=None, parse_dates=[1])