meerschaum 2.6.13__py3-none-any.whl → 2.6.15__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,520 +0,0 @@
1
- Metadata-Version: 2.1
2
- Name: meerschaum
3
- Version: 2.6.13
4
- Summary: Sync Time-Series Pipes with Meerschaum
5
- Home-page: https://meerschaum.io
6
- Author: Bennett Meares
7
- Author-email: bennett.meares@gmail.com
8
- Maintainer-email: bennett.meares@gmail.com
9
- License: Apache Software License 2.0
10
- Project-URL: Documentation, https://docs.meerschaum.io
11
- Project-URL: Changelog, https://meerschaum.io/news/changelog
12
- Project-URL: GitHub, https://github.com/bmeares/Meerschaum
13
- Project-URL: Homepage, https://meerschaum.io
14
- Project-URL: Donate, https://github.com/sponsors/bmeares
15
- Project-URL: Discord, https://discord.gg/8U8qMUjvcc
16
- Classifier: Development Status :: 5 - Production/Stable
17
- Classifier: Intended Audience :: System Administrators
18
- Classifier: License :: OSI Approved :: Apache Software License
19
- Classifier: Operating System :: POSIX :: Linux
20
- Classifier: Operating System :: Microsoft :: Windows
21
- Classifier: Operating System :: MacOS
22
- Classifier: Programming Language :: SQL
23
- Classifier: Programming Language :: Python :: 3.9
24
- Classifier: Programming Language :: Python :: 3.10
25
- Classifier: Programming Language :: Python :: 3.11
26
- Classifier: Programming Language :: Python :: 3.12
27
- Classifier: Programming Language :: Python :: 3.13
28
- Classifier: Topic :: Database
29
- Classifier: Natural Language :: English
30
- Requires-Python: >=3.8
31
- Description-Content-Type: text/markdown
32
- License-File: LICENSE
33
- License-File: NOTICE
34
- Provides-Extra: api
35
- Requires-Dist: uvicorn[standard] >=0.29.0 ; extra == 'api'
36
- Requires-Dist: gunicorn >=22.0.0 ; extra == 'api'
37
- Requires-Dist: python-dotenv >=0.20.0 ; extra == 'api'
38
- Requires-Dist: websockets >=11.0.3 ; extra == 'api'
39
- Requires-Dist: fastapi >=0.111.0 ; extra == 'api'
40
- Requires-Dist: fastapi-login >=1.7.2 ; extra == 'api'
41
- Requires-Dist: python-multipart >=0.0.9 ; extra == 'api'
42
- Requires-Dist: httpx >=0.27.2 ; extra == 'api'
43
- Requires-Dist: httpcore >=1.0.6 ; extra == 'api'
44
- Requires-Dist: valkey >=6.0.0 ; extra == 'api'
45
- Requires-Dist: numpy >=1.18.5 ; extra == 'api'
46
- Requires-Dist: pandas[parquet] >=2.0.1 ; extra == 'api'
47
- Requires-Dist: pyarrow >=16.1.0 ; extra == 'api'
48
- Requires-Dist: dask[complete] >=2024.5.1 ; extra == 'api'
49
- Requires-Dist: partd >=1.4.2 ; extra == 'api'
50
- Requires-Dist: pytz ; extra == 'api'
51
- Requires-Dist: joblib >=0.17.0 ; extra == 'api'
52
- Requires-Dist: SQLAlchemy >=2.0.5 ; extra == 'api'
53
- Requires-Dist: databases >=0.4.0 ; extra == 'api'
54
- Requires-Dist: aiosqlite >=0.16.0 ; extra == 'api'
55
- Requires-Dist: asyncpg >=0.21.0 ; extra == 'api'
56
- Requires-Dist: cryptography >=38.0.1 ; extra == 'api'
57
- Requires-Dist: psycopg[binary] >=3.2.1 ; extra == 'api'
58
- Requires-Dist: PyMySQL >=0.9.0 ; extra == 'api'
59
- Requires-Dist: aiomysql >=0.0.21 ; extra == 'api'
60
- Requires-Dist: sqlalchemy-cockroachdb >=2.0.0 ; extra == 'api'
61
- Requires-Dist: duckdb >=1.0.0 ; extra == 'api'
62
- Requires-Dist: duckdb-engine >=0.13.0 ; extra == 'api'
63
- Requires-Dist: wheel >=0.34.2 ; extra == 'api'
64
- Requires-Dist: setuptools >=63.3.0 ; extra == 'api'
65
- Requires-Dist: PyYAML >=5.3.1 ; extra == 'api'
66
- Requires-Dist: pip >=22.0.4 ; extra == 'api'
67
- Requires-Dist: update-checker >=0.18.0 ; extra == 'api'
68
- Requires-Dist: semver >=3.0.2 ; extra == 'api'
69
- Requires-Dist: pathspec >=0.9.0 ; extra == 'api'
70
- Requires-Dist: python-dateutil >=2.7.5 ; extra == 'api'
71
- Requires-Dist: requests >=2.32.3 ; extra == 'api'
72
- Requires-Dist: certifi >=2024.8.30 ; extra == 'api'
73
- Requires-Dist: idna >=3.10.0 ; extra == 'api'
74
- Requires-Dist: binaryornot >=0.4.4 ; extra == 'api'
75
- Requires-Dist: pyvim >=3.0.2 ; extra == 'api'
76
- Requires-Dist: ptpython >=3.0.27 ; extra == 'api'
77
- Requires-Dist: aiofiles >=0.6.0 ; extra == 'api'
78
- Requires-Dist: packaging >=21.3.0 ; extra == 'api'
79
- Requires-Dist: prompt-toolkit >=3.0.39 ; extra == 'api'
80
- Requires-Dist: more-itertools >=8.7.0 ; extra == 'api'
81
- Requires-Dist: fasteners >=0.19.0 ; extra == 'api'
82
- Requires-Dist: virtualenv >=20.1.0 ; extra == 'api'
83
- Requires-Dist: attrs >=24.2.0 ; extra == 'api'
84
- Requires-Dist: uv >=0.2.11 ; extra == 'api'
85
- Requires-Dist: pprintpp >=0.4.0 ; extra == 'api'
86
- Requires-Dist: asciitree >=0.3.3 ; extra == 'api'
87
- Requires-Dist: typing-extensions >=4.7.1 ; extra == 'api'
88
- Requires-Dist: pygments >=2.7.2 ; extra == 'api'
89
- Requires-Dist: colorama >=0.4.3 ; extra == 'api'
90
- Requires-Dist: rich >=13.4.2 ; extra == 'api'
91
- Requires-Dist: more-termcolor >=1.1.3 ; extra == 'api'
92
- Requires-Dist: humanfriendly >=10.0.0 ; extra == 'api'
93
- Requires-Dist: Flask-Compress >=1.10.1 ; extra == 'api'
94
- Requires-Dist: dash >=2.6.2 ; extra == 'api'
95
- Requires-Dist: dash-bootstrap-components >=1.2.1 ; extra == 'api'
96
- Requires-Dist: dash-ace >=0.2.1 ; extra == 'api'
97
- Requires-Dist: dash-extensions >=1.0.4 ; extra == 'api'
98
- Requires-Dist: dataclass-wizard >=0.28.0 ; extra == 'api'
99
- Requires-Dist: dash-daq >=0.5.0 ; extra == 'api'
100
- Requires-Dist: terminado >=0.12.1 ; extra == 'api'
101
- Requires-Dist: tornado >=6.1.0 ; extra == 'api'
102
- Requires-Dist: dill >=0.3.3 ; extra == 'api'
103
- Requires-Dist: python-daemon >=0.2.3 ; extra == 'api'
104
- Requires-Dist: watchfiles >=0.21.0 ; extra == 'api'
105
- Requires-Dist: psutil >=5.8.0 ; extra == 'api'
106
- Provides-Extra: build
107
- Requires-Dist: cx-Freeze >=7.0.0 ; extra == 'build'
108
- Requires-Dist: pyinstaller >6.6.0 ; extra == 'build'
109
- Provides-Extra: cli
110
- Requires-Dist: pgcli >=3.1.0 ; extra == 'cli'
111
- Requires-Dist: mycli >=1.23.2 ; extra == 'cli'
112
- Requires-Dist: litecli >=1.5.0 ; extra == 'cli'
113
- Requires-Dist: mssql-cli >=1.0.0 ; extra == 'cli'
114
- Requires-Dist: gadwall >=0.2.0 ; extra == 'cli'
115
- Provides-Extra: core
116
- Requires-Dist: wheel >=0.34.2 ; extra == 'core'
117
- Requires-Dist: setuptools >=63.3.0 ; extra == 'core'
118
- Requires-Dist: PyYAML >=5.3.1 ; extra == 'core'
119
- Requires-Dist: pip >=22.0.4 ; extra == 'core'
120
- Requires-Dist: update-checker >=0.18.0 ; extra == 'core'
121
- Requires-Dist: semver >=3.0.2 ; extra == 'core'
122
- Requires-Dist: pathspec >=0.9.0 ; extra == 'core'
123
- Requires-Dist: python-dateutil >=2.7.5 ; extra == 'core'
124
- Requires-Dist: requests >=2.32.3 ; extra == 'core'
125
- Requires-Dist: certifi >=2024.8.30 ; extra == 'core'
126
- Requires-Dist: idna >=3.10.0 ; extra == 'core'
127
- Requires-Dist: binaryornot >=0.4.4 ; extra == 'core'
128
- Requires-Dist: pyvim >=3.0.2 ; extra == 'core'
129
- Requires-Dist: ptpython >=3.0.27 ; extra == 'core'
130
- Requires-Dist: aiofiles >=0.6.0 ; extra == 'core'
131
- Requires-Dist: packaging >=21.3.0 ; extra == 'core'
132
- Requires-Dist: prompt-toolkit >=3.0.39 ; extra == 'core'
133
- Requires-Dist: more-itertools >=8.7.0 ; extra == 'core'
134
- Requires-Dist: fasteners >=0.19.0 ; extra == 'core'
135
- Requires-Dist: virtualenv >=20.1.0 ; extra == 'core'
136
- Requires-Dist: attrs >=24.2.0 ; extra == 'core'
137
- Requires-Dist: uv >=0.2.11 ; extra == 'core'
138
- Provides-Extra: dash
139
- Requires-Dist: Flask-Compress >=1.10.1 ; extra == 'dash'
140
- Requires-Dist: dash >=2.6.2 ; extra == 'dash'
141
- Requires-Dist: dash-bootstrap-components >=1.2.1 ; extra == 'dash'
142
- Requires-Dist: dash-ace >=0.2.1 ; extra == 'dash'
143
- Requires-Dist: dash-extensions >=1.0.4 ; extra == 'dash'
144
- Requires-Dist: dataclass-wizard >=0.28.0 ; extra == 'dash'
145
- Requires-Dist: dash-daq >=0.5.0 ; extra == 'dash'
146
- Requires-Dist: terminado >=0.12.1 ; extra == 'dash'
147
- Requires-Dist: tornado >=6.1.0 ; extra == 'dash'
148
- Provides-Extra: dev-tools
149
- Requires-Dist: twine >=3.2.0 ; extra == 'dev-tools'
150
- Requires-Dist: tuna >=0.5.3 ; extra == 'dev-tools'
151
- Requires-Dist: snakeviz >=2.1.0 ; extra == 'dev-tools'
152
- Requires-Dist: mypy >=0.812.0 ; extra == 'dev-tools'
153
- Requires-Dist: pytest >=6.2.2 ; extra == 'dev-tools'
154
- Requires-Dist: pytest-xdist >=3.2.1 ; extra == 'dev-tools'
155
- Requires-Dist: heartrate >=0.2.1 ; extra == 'dev-tools'
156
- Requires-Dist: build >=1.2.1 ; extra == 'dev-tools'
157
- Requires-Dist: attrs >=24.2.0 ; extra == 'dev-tools'
158
- Provides-Extra: docs
159
- Requires-Dist: mkdocs >=1.1.2 ; extra == 'docs'
160
- Requires-Dist: mkdocs-material >=6.2.5 ; extra == 'docs'
161
- Requires-Dist: mkdocs-material-extensions >=1.0.3 ; extra == 'docs'
162
- Requires-Dist: mkdocs-autolinks-plugin >=0.2.0 ; extra == 'docs'
163
- Requires-Dist: mkdocs-awesome-pages-plugin >=2.5.0 ; extra == 'docs'
164
- Requires-Dist: mkdocs-section-index >=0.3.3 ; extra == 'docs'
165
- Requires-Dist: mkdocs-linkcheck >=1.0.6 ; extra == 'docs'
166
- Requires-Dist: mkdocs-redirects >=1.0.4 ; extra == 'docs'
167
- Requires-Dist: jinja2 ==3.0.3 ; extra == 'docs'
168
- Provides-Extra: drivers
169
- Requires-Dist: cryptography >=38.0.1 ; extra == 'drivers'
170
- Requires-Dist: psycopg[binary] >=3.2.1 ; extra == 'drivers'
171
- Requires-Dist: PyMySQL >=0.9.0 ; extra == 'drivers'
172
- Requires-Dist: aiomysql >=0.0.21 ; extra == 'drivers'
173
- Requires-Dist: sqlalchemy-cockroachdb >=2.0.0 ; extra == 'drivers'
174
- Requires-Dist: duckdb >=1.0.0 ; extra == 'drivers'
175
- Requires-Dist: duckdb-engine >=0.13.0 ; extra == 'drivers'
176
- Provides-Extra: drivers-extras
177
- Requires-Dist: pyodbc >=4.0.30 ; extra == 'drivers-extras'
178
- Requires-Dist: cx-Oracle >=8.3.0 ; extra == 'drivers-extras'
179
- Provides-Extra: extras
180
- Requires-Dist: cmd2 >=1.4.0 ; extra == 'extras'
181
- Requires-Dist: ruamel.yaml >=0.16.12 ; extra == 'extras'
182
- Requires-Dist: modin[ray] >=0.8.3 ; extra == 'extras'
183
- Requires-Dist: nanoid >=2.0.0 ; extra == 'extras'
184
- Requires-Dist: importlib-metadata >=4.12.0 ; extra == 'extras'
185
- Provides-Extra: formatting
186
- Requires-Dist: pprintpp >=0.4.0 ; extra == 'formatting'
187
- Requires-Dist: asciitree >=0.3.3 ; extra == 'formatting'
188
- Requires-Dist: typing-extensions >=4.7.1 ; extra == 'formatting'
189
- Requires-Dist: pygments >=2.7.2 ; extra == 'formatting'
190
- Requires-Dist: colorama >=0.4.3 ; extra == 'formatting'
191
- Requires-Dist: rich >=13.4.2 ; extra == 'formatting'
192
- Requires-Dist: more-termcolor >=1.1.3 ; extra == 'formatting'
193
- Requires-Dist: humanfriendly >=10.0.0 ; extra == 'formatting'
194
- Provides-Extra: full
195
- Requires-Dist: pprintpp >=0.4.0 ; extra == 'full'
196
- Requires-Dist: asciitree >=0.3.3 ; extra == 'full'
197
- Requires-Dist: typing-extensions >=4.7.1 ; extra == 'full'
198
- Requires-Dist: pygments >=2.7.2 ; extra == 'full'
199
- Requires-Dist: colorama >=0.4.3 ; extra == 'full'
200
- Requires-Dist: rich >=13.4.2 ; extra == 'full'
201
- Requires-Dist: more-termcolor >=1.1.3 ; extra == 'full'
202
- Requires-Dist: humanfriendly >=10.0.0 ; extra == 'full'
203
- Requires-Dist: wheel >=0.34.2 ; extra == 'full'
204
- Requires-Dist: setuptools >=63.3.0 ; extra == 'full'
205
- Requires-Dist: PyYAML >=5.3.1 ; extra == 'full'
206
- Requires-Dist: pip >=22.0.4 ; extra == 'full'
207
- Requires-Dist: update-checker >=0.18.0 ; extra == 'full'
208
- Requires-Dist: semver >=3.0.2 ; extra == 'full'
209
- Requires-Dist: pathspec >=0.9.0 ; extra == 'full'
210
- Requires-Dist: python-dateutil >=2.7.5 ; extra == 'full'
211
- Requires-Dist: requests >=2.32.3 ; extra == 'full'
212
- Requires-Dist: certifi >=2024.8.30 ; extra == 'full'
213
- Requires-Dist: idna >=3.10.0 ; extra == 'full'
214
- Requires-Dist: binaryornot >=0.4.4 ; extra == 'full'
215
- Requires-Dist: pyvim >=3.0.2 ; extra == 'full'
216
- Requires-Dist: ptpython >=3.0.27 ; extra == 'full'
217
- Requires-Dist: aiofiles >=0.6.0 ; extra == 'full'
218
- Requires-Dist: packaging >=21.3.0 ; extra == 'full'
219
- Requires-Dist: prompt-toolkit >=3.0.39 ; extra == 'full'
220
- Requires-Dist: more-itertools >=8.7.0 ; extra == 'full'
221
- Requires-Dist: fasteners >=0.19.0 ; extra == 'full'
222
- Requires-Dist: virtualenv >=20.1.0 ; extra == 'full'
223
- Requires-Dist: attrs >=24.2.0 ; extra == 'full'
224
- Requires-Dist: uv >=0.2.11 ; extra == 'full'
225
- Requires-Dist: dill >=0.3.3 ; extra == 'full'
226
- Requires-Dist: python-daemon >=0.2.3 ; extra == 'full'
227
- Requires-Dist: watchfiles >=0.21.0 ; extra == 'full'
228
- Requires-Dist: psutil >=5.8.0 ; extra == 'full'
229
- Requires-Dist: cryptography >=38.0.1 ; extra == 'full'
230
- Requires-Dist: psycopg[binary] >=3.2.1 ; extra == 'full'
231
- Requires-Dist: PyMySQL >=0.9.0 ; extra == 'full'
232
- Requires-Dist: aiomysql >=0.0.21 ; extra == 'full'
233
- Requires-Dist: sqlalchemy-cockroachdb >=2.0.0 ; extra == 'full'
234
- Requires-Dist: duckdb >=1.0.0 ; extra == 'full'
235
- Requires-Dist: duckdb-engine >=0.13.0 ; extra == 'full'
236
- Requires-Dist: toga >=0.3.0-dev29 ; extra == 'full'
237
- Requires-Dist: pywebview >=3.6.3 ; extra == 'full'
238
- Requires-Dist: pycparser >=2.21.0 ; extra == 'full'
239
- Requires-Dist: numpy >=1.18.5 ; extra == 'full'
240
- Requires-Dist: pandas[parquet] >=2.0.1 ; extra == 'full'
241
- Requires-Dist: pyarrow >=16.1.0 ; extra == 'full'
242
- Requires-Dist: dask[complete] >=2024.5.1 ; extra == 'full'
243
- Requires-Dist: partd >=1.4.2 ; extra == 'full'
244
- Requires-Dist: pytz ; extra == 'full'
245
- Requires-Dist: joblib >=0.17.0 ; extra == 'full'
246
- Requires-Dist: SQLAlchemy >=2.0.5 ; extra == 'full'
247
- Requires-Dist: databases >=0.4.0 ; extra == 'full'
248
- Requires-Dist: aiosqlite >=0.16.0 ; extra == 'full'
249
- Requires-Dist: asyncpg >=0.21.0 ; extra == 'full'
250
- Requires-Dist: Flask-Compress >=1.10.1 ; extra == 'full'
251
- Requires-Dist: dash >=2.6.2 ; extra == 'full'
252
- Requires-Dist: dash-bootstrap-components >=1.2.1 ; extra == 'full'
253
- Requires-Dist: dash-ace >=0.2.1 ; extra == 'full'
254
- Requires-Dist: dash-extensions >=1.0.4 ; extra == 'full'
255
- Requires-Dist: dataclass-wizard >=0.28.0 ; extra == 'full'
256
- Requires-Dist: dash-daq >=0.5.0 ; extra == 'full'
257
- Requires-Dist: terminado >=0.12.1 ; extra == 'full'
258
- Requires-Dist: tornado >=6.1.0 ; extra == 'full'
259
- Requires-Dist: uvicorn[standard] >=0.29.0 ; extra == 'full'
260
- Requires-Dist: gunicorn >=22.0.0 ; extra == 'full'
261
- Requires-Dist: python-dotenv >=0.20.0 ; extra == 'full'
262
- Requires-Dist: websockets >=11.0.3 ; extra == 'full'
263
- Requires-Dist: fastapi >=0.111.0 ; extra == 'full'
264
- Requires-Dist: fastapi-login >=1.7.2 ; extra == 'full'
265
- Requires-Dist: python-multipart >=0.0.9 ; extra == 'full'
266
- Requires-Dist: httpx >=0.27.2 ; extra == 'full'
267
- Requires-Dist: httpcore >=1.0.6 ; extra == 'full'
268
- Requires-Dist: valkey >=6.0.0 ; extra == 'full'
269
- Provides-Extra: gui
270
- Requires-Dist: toga >=0.3.0-dev29 ; extra == 'gui'
271
- Requires-Dist: pywebview >=3.6.3 ; extra == 'gui'
272
- Requires-Dist: pycparser >=2.21.0 ; extra == 'gui'
273
- Provides-Extra: jobs
274
- Requires-Dist: dill >=0.3.3 ; extra == 'jobs'
275
- Requires-Dist: python-daemon >=0.2.3 ; extra == 'jobs'
276
- Requires-Dist: watchfiles >=0.21.0 ; extra == 'jobs'
277
- Requires-Dist: psutil >=5.8.0 ; extra == 'jobs'
278
- Provides-Extra: minimal
279
- Provides-Extra: required
280
- Provides-Extra: setup
281
- Provides-Extra: sql
282
- Requires-Dist: numpy >=1.18.5 ; extra == 'sql'
283
- Requires-Dist: pandas[parquet] >=2.0.1 ; extra == 'sql'
284
- Requires-Dist: pyarrow >=16.1.0 ; extra == 'sql'
285
- Requires-Dist: dask[complete] >=2024.5.1 ; extra == 'sql'
286
- Requires-Dist: partd >=1.4.2 ; extra == 'sql'
287
- Requires-Dist: pytz ; extra == 'sql'
288
- Requires-Dist: joblib >=0.17.0 ; extra == 'sql'
289
- Requires-Dist: SQLAlchemy >=2.0.5 ; extra == 'sql'
290
- Requires-Dist: databases >=0.4.0 ; extra == 'sql'
291
- Requires-Dist: aiosqlite >=0.16.0 ; extra == 'sql'
292
- Requires-Dist: asyncpg >=0.21.0 ; extra == 'sql'
293
- Requires-Dist: cryptography >=38.0.1 ; extra == 'sql'
294
- Requires-Dist: psycopg[binary] >=3.2.1 ; extra == 'sql'
295
- Requires-Dist: PyMySQL >=0.9.0 ; extra == 'sql'
296
- Requires-Dist: aiomysql >=0.0.21 ; extra == 'sql'
297
- Requires-Dist: sqlalchemy-cockroachdb >=2.0.0 ; extra == 'sql'
298
- Requires-Dist: duckdb >=1.0.0 ; extra == 'sql'
299
- Requires-Dist: duckdb-engine >=0.13.0 ; extra == 'sql'
300
- Requires-Dist: wheel >=0.34.2 ; extra == 'sql'
301
- Requires-Dist: setuptools >=63.3.0 ; extra == 'sql'
302
- Requires-Dist: PyYAML >=5.3.1 ; extra == 'sql'
303
- Requires-Dist: pip >=22.0.4 ; extra == 'sql'
304
- Requires-Dist: update-checker >=0.18.0 ; extra == 'sql'
305
- Requires-Dist: semver >=3.0.2 ; extra == 'sql'
306
- Requires-Dist: pathspec >=0.9.0 ; extra == 'sql'
307
- Requires-Dist: python-dateutil >=2.7.5 ; extra == 'sql'
308
- Requires-Dist: requests >=2.32.3 ; extra == 'sql'
309
- Requires-Dist: certifi >=2024.8.30 ; extra == 'sql'
310
- Requires-Dist: idna >=3.10.0 ; extra == 'sql'
311
- Requires-Dist: binaryornot >=0.4.4 ; extra == 'sql'
312
- Requires-Dist: pyvim >=3.0.2 ; extra == 'sql'
313
- Requires-Dist: ptpython >=3.0.27 ; extra == 'sql'
314
- Requires-Dist: aiofiles >=0.6.0 ; extra == 'sql'
315
- Requires-Dist: packaging >=21.3.0 ; extra == 'sql'
316
- Requires-Dist: prompt-toolkit >=3.0.39 ; extra == 'sql'
317
- Requires-Dist: more-itertools >=8.7.0 ; extra == 'sql'
318
- Requires-Dist: fasteners >=0.19.0 ; extra == 'sql'
319
- Requires-Dist: virtualenv >=20.1.0 ; extra == 'sql'
320
- Requires-Dist: attrs >=24.2.0 ; extra == 'sql'
321
- Requires-Dist: uv >=0.2.11 ; extra == 'sql'
322
- Provides-Extra: stack
323
- Requires-Dist: docker-compose >=1.29.2 ; extra == 'stack'
324
-
325
- <img src="https://meerschaum.io/assets/banner_1920x320.png" alt="Meerschaum banner" style="width: 100%"/>
326
-
327
- | PyPI | GitHub | Info | Stats |
328
- |---|---|---|---|
329
- | ![PyPI]( https://img.shields.io/pypi/v/meerschaum?color=%2300cc66&label=Version ) | ![GitHub Repo stars](https://img.shields.io/github/stars/bmeares/Meerschaum?style=social) | ![License](https://img.shields.io/github/license/bmeares/Meerschaum?label=License) | ![Number of plugins]( https://img.shields.io/badge/dynamic/json?color=3098c1&label=Public%20Plugins&query=num_plugins&url=https%3A%2F%2Fapi.mrsm.io%2Finfo ) |
330
- | ![PyPI - Python Version]( https://img.shields.io/pypi/pyversions/meerschaum?label=Python&logo=python&logoColor=%23ffffff ) | ![GitHub Sponsors](https://img.shields.io/github/sponsors/bmeares?color=eadf15&label=Sponsors) | [![Artifact Hub](https://img.shields.io/endpoint?url=https://artifacthub.io/badge/repository/meerschaum)](https://artifacthub.io/packages/search?repo=meerschaum) | ![Number of registered users]( https://img.shields.io/badge/dynamic/json?color=3098c1&label=Registered%20Users&query=num_users&url=https%3A%2F%2Fapi.mrsm.io%2Finfo ) |
331
-
332
- <p align="center">
333
- <img src="https://meerschaum.io/files/images/demo.gif" alt="Meerschaum demo" height="450px">
334
- </p>
335
-
336
- ## What is Meerschaum?
337
- Meerschaum is a tool for quickly synchronizing time-series data streams called **pipes**. With Meerschaum, you can have a data visualization stack running in minutes.
338
-
339
- <p align="center">
340
- <img src="https://meerschaum.io/assets/screenshots/weather_pipes.png"/>
341
- </p>
342
-
343
- ## Why Meerschaum?
344
-
345
- Two words: *incremental updates*. Fetch the data you need, and Meerschaum will handle the rest.
346
-
347
- If you've worked with time-series data, you know the headaches that come with ETL.
348
- Data engineering often gets in analysts' way, and when work needs to get done, every minute spent on pipelining is time taken away from real analysis.
349
-
350
- Rather than copy / pasting your ETL scripts, simply build pipes with Meerschaum! [Meerschaum gives you the tools to design your data streams how you like](https://towardsdatascience.com/easy-time-series-etl-for-data-scientists-with-meerschaum-5aade339b398) ― and don't worry — you can always incorporate Meerschaum into your existing systems!
351
-
352
- ### Want to Learn More?
353
-
354
- You can find a wealth of information at [meerschaum.io](https://meerschaum.io)!
355
-
356
- Additionally, below are several articles published about Meerschaum:
357
-
358
- - Interview featured in [*Console 100 - The Open Source Newsletter*](https://console.substack.com/p/console-100)
359
- - [*A Data Scientist's Guide to Fetching COVID-19 Data in 2022*](https://towardsdatascience.com/a-data-scientists-guide-to-fetching-covid-19-data-in-2022-d952b4697) (Towards Data Science)
360
- - [*Time-Series ETL with Meerschaum*](https://towardsdatascience.com/easy-time-series-etl-for-data-scientists-with-meerschaum-5aade339b398) (Towards Data Science)
361
- - [*How I automatically extract my M1 Finance transactions*](https://bmeares.medium.com/how-i-automatically-extract-my-m1-finance-transactions-b43cef857bc7)
362
-
363
- ## Installation
364
-
365
- For a more thorough setup guide, visit the [Getting Started](https://meerschaum.io/get-started/) page at [meerschaum.io](https://meerschaum.io).
366
-
367
- ### TL;DR
368
-
369
- ```bash
370
- pip install -U --user meerschaum
371
- mrsm stack up -d db grafana
372
- mrsm bootstrap pipes
373
- ```
374
-
375
- ## Usage
376
-
377
- Please visit [meerschaum.io](https://meerschaum.io) for setup, usage, and troubleshooting information. You can find technical documentation at [docs.meerschaum.io](https://docs.meerschaum.io), and here is a complete list of the [Meerschaum actions](https://meerschaum.io/reference/actions/).
378
-
379
- ### CLI
380
- ```bash
381
- ### Install the NOAA weather plugin.
382
- mrsm install plugin noaa
383
-
384
- ### Register a new pipe to the built-in SQLite DB.
385
- ### You can instead run `bootstrap pipe` for a wizard.
386
- ### Enter 'KATL' for Atlanta when prompted.
387
- mrsm register pipe -c plugin:noaa -m weather -l atl -i sql:local
388
-
389
- ### Pull data and create the table "plugin_noaa_weather_atl".
390
- mrsm sync pipes -l atl -i sql:local
391
- ```
392
-
393
- ### Python API
394
-
395
- ```python
396
- import meerschaum as mrsm
397
- pipe = mrsm.Pipe(
398
- 'foo', 'bar', ### Connector and metric labels.
399
- target = 'MyTableName!', ### Table name. Defaults to 'foo_bar'.
400
- instance = 'sql:local', ### Built-in SQLite DB. Defaults to 'sql:main'.
401
- columns = {
402
- 'datetime': 'dt', ### Column for the datetime index.
403
- 'id' : 'id', ### Column for the ID index (optional).
404
- },
405
- )
406
- ### Pass a DataFrame to create the table and indices.
407
- pipe.sync([{'dt': '2022-07-01', 'id': 1, 'val': 10}])
408
-
409
- ### Duplicate rows are ignored.
410
- pipe.sync([{'dt': '2022-07-01', 'id': 1, 'val': 10}])
411
- assert len(pipe.get_data()) == 1
412
-
413
- ### Rows with existing keys (datetime and/or id) are updated.
414
- pipe.sync([{'dt': '2022-07-01', 'id': 1, 'val': 100}])
415
- assert len(pipe.get_data()) == 1
416
-
417
- ### Translates to this query for SQLite:
418
- ###
419
- ### SELECT *
420
- ### FROM "MyTableName!"
421
- ### WHERE "dt" >= datetime('2022-01-01', '0 minute')
422
- ### AND "dt" < datetime('2023-01-01', '0 minute')
423
- ### AND "id" IN ('1')
424
- df = pipe.get_data(
425
- begin = '2022-01-01',
426
- end = '2023-01-01',
427
- params = {'id': [1]},
428
- )
429
-
430
- ### Shape of the DataFrame:
431
- ### dt id val
432
- ### 0 2022-07-01 1 100
433
-
434
- ### Drop the table and remove the pipe's metadata.
435
- pipe.delete()
436
- ```
437
-
438
- ### Simple Plugin
439
-
440
- ```python
441
- # ~/.config/plugins/example.py
442
-
443
- __version__ = '1.0.0'
444
- required = ['requests']
445
-
446
- def register(pipe, **kw):
447
- return {
448
- 'columns': {
449
- 'datetime': 'dt',
450
- 'id' : 'id',
451
- },
452
- }
453
-
454
- def fetch(pipe, **kw):
455
- import requests, datetime, random
456
- response = requests.get('http://date.jsontest.com/')
457
-
458
- ### The fetched JSON has the following shape:
459
- ### {
460
- ### "date": "07-01-2022",
461
- ### "milliseconds_since_epoch": 1656718801566,
462
- ### "time": "11:40:01 PM"
463
- ### }
464
- data = response.json()
465
- timestamp = datetime.datetime.fromtimestamp(
466
- int(str(data['milliseconds_since_epoch'])[:-3])
467
- )
468
-
469
- ### You may also return a Pandas DataFrame.
470
- return [{
471
- "dt" : timestamp,
472
- "id" : random.randint(1, 4),
473
- "value": random.uniform(1, 100),
474
- }]
475
- ```
476
-
477
- ## Features
478
-
479
- - 📊 **Built for Data Scientists and Analysts**
480
- - Integrate with Pandas, Grafana and other popular [data analysis tools](https://meerschaum.io/reference/data-analysis-tools/).
481
- - Persist your dataframes and always get the latest data.
482
- - ⚡️ **Production-Ready, Batteries Included**
483
- - [Synchronization engine](https://meerschaum.io/reference/pipes/syncing/) concurrently updates many time-series data streams.
484
- - One-click deploy a [TimescaleDB and Grafana stack](https://meerschaum.io/reference/stack/) for prototyping.
485
- - Serve data to your entire organization through the power of `uvicorn`, `gunicorn`, and `FastAPI`.
486
- - 🔌 **Easily Expandable**
487
- - Ingest any data source with a simple [plugin](https://meerschaum.io/reference/plugins/writing-plugins/). Just return a DataFrame, and Meerschaum handles the rest.
488
- - [Add any function as a command](https://meerschaum.io/reference/plugins/types-of-plugins/#action-plugins) to the Meerschaum system.
489
- - Include Meerschaum in your projects with its [easy-to-use Python API](https://docs.meerschaum.io).
490
- - ✨ **Tailored for Your Experience**
491
- - Rich CLI makes managing your data streams surprisingly enjoyable!
492
- - Web dashboard for those who prefer a more graphical experience.
493
- - Manage your database connections with [Meerschaum connectors](https://meerschaum.io/reference/connectors/).
494
- - Utility commands with sensible syntax let you control many pipes with grace.
495
- - 💼 **Portable from the Start**
496
- - The environment variable `$MRSM_ROOT_DIR` lets you emulate multiple installations and group together your [instances](https://meerschaum.io/reference/connectors/#instances-and-repositories).
497
- - No dependencies required; anything needed will be installed into a virtual environment.
498
- - [Specify required packages for your plugins](https://meerschaum.io/reference/plugins/writing-plugins/), and users will get those packages in a virtual environment.
499
-
500
- ## Support Meerschaum's Development
501
-
502
- For consulting services and to support Meerschaum's development, please considering sponsoring me on [GitHub sponsors](https://github.com/sponsors/bmeares).
503
-
504
- Additionally, you can always [buy me a coffee☕](https://www.buymeacoffee.com/bmeares)!
505
-
506
- ### License
507
-
508
- Copyright 2021 Bennett Meares
509
-
510
- Licensed under the Apache License, Version 2.0 (the "License");
511
- you may not use this file except in compliance with the License.
512
- You may obtain a copy of the License at
513
-
514
- http://www.apache.org/licenses/LICENSE-2.0
515
-
516
- Unless required by applicable law or agreed to in writing, software
517
- distributed under the License is distributed on an "AS IS" BASIS,
518
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
519
- See the License for the specific language governing permissions and
520
- limitations under the License.