Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add write_dir argument to csv_to_wfdb. Fixes #67. #492

Merged
merged 4 commits into from
Jul 11, 2024

Conversation

tompollard
Copy link
Member

@tompollard tompollard commented Jul 1, 2024

As discussed in #490,

def csv_to_wfdb(
currently "strips the path from the input .csv, then writes the output to .dat and .hea".

It's inconvenient not to be able to specify the output directory. This pull request adds a new output_dir argument to the csv_to_wfdb function. By default output_dir is set to None, which will maintain backwards compatibility. Setting output_dir to a directory will mean that output files are saved to this directory.

I have set this to a WIP, because I haven't tested the new behaviour (other than running pytest). @jshaffer94247, if you have an opportunity to test the fix, I'd appreciate your feedback.

@tompollard tompollard force-pushed the tp/csv_to_wfdb_path branch 2 times, most recently from d6d5aa7 to caff031 Compare July 1, 2024 19:36
@tompollard
Copy link
Member Author

tompollard commented Jul 2, 2024

Tests are failing on an unrelated issue, presumably related to an update to Numpy (e.g. this? https://numpy.org/devdocs/release/1.24.0-notes.html#conversion-of-out-of-bound-python-integers)

@bemoody
Copy link
Collaborator

bemoody commented Jul 2, 2024

It should be write_dir to be consistent with wrsamp, wrann, etc.

The existing logic is pretty broken, though! split(os.sep) is decidedly wrong for Windows, but also replace(".csv", "") is screwy. You want to take the basename and then remove anything after a dot.

@tompollard tompollard changed the title [WIP] Add output_dir argument to csv_to_wfdb. Fixes #67. [WIP] Add write_dir argument to csv_to_wfdb. Fixes #67. Jul 3, 2024
@tompollard tompollard force-pushed the tp/csv_to_wfdb_path branch from 8463fe6 to d9f4e3c Compare July 3, 2024 18:30
@bemoody
Copy link
Collaborator

bemoody commented Jul 3, 2024

No test cases - please add a test case so we can see that this function works.

@tompollard tompollard force-pushed the tp/csv_to_wfdb_path branch from d9f4e3c to 626307a Compare July 9, 2024 19:59
@tompollard tompollard force-pushed the tp/csv_to_wfdb_path branch from 626307a to e6b3b69 Compare July 9, 2024 20:45
…r earlier versions.

Tests are failing on the test-deb10-i386 build because it is running an old version of Pandas.
@tompollard tompollard changed the title [WIP] Add write_dir argument to csv_to_wfdb. Fixes #67. Add write_dir argument to csv_to_wfdb. Fixes #67. Jul 9, 2024
@tompollard
Copy link
Member Author

@bemoody this is now ready to review.

@bemoody
Copy link
Collaborator

bemoody commented Jul 11, 2024

pandas/core/base.py says "tolist is not deprecated" (to_list is an alias for tolist), so can we simply use tolist?

@tompollard
Copy link
Member Author

pandas/core/base.py says "tolist is not deprecated" (to_list is an alias for tolist), so can we simply use tolist?

I considered this but decided to use to_list() because it sounds like it is what the developers would like us to use (I think for consistency with other pandas methods). I think dropping the try/except is fine though...now done.

Copy link
Collaborator

@bemoody bemoody left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks - looks good!

@tompollard
Copy link
Member Author

Thanks Benjamin

@tompollard tompollard merged commit 6a0de80 into main Jul 11, 2024
14 checks passed
@tompollard tompollard deleted the tp/csv_to_wfdb_path branch July 11, 2024 18:28
tompollard added a commit that referenced this pull request Jan 21, 2025
This pull request adds a changelog for `v4.2.0`. The changelog is based
on the following auto-generated summary of merge commits generated by
GitHub:

```
## What's Changed

* bug-fix: Numpy ValueError when cheking empty list equality by @ajadczaksunriselabs in #459
* bug-fix: Pandas set indexing error by @ajadczaksunriselabs in #460
* fix for /issues/452 by @tecamenz in #465
* Use numpydoc to render documentation by @SnoopJ in #472
* build(deps): bump readthedocs-sphinx-search from 0.1.1 to 0.3.2 in /docs by @dependabot in #477
* Update style by @bemoody in #482
* Fix NaN handling in Record.adc, and other fixes by @bemoody in #481
* Set upper bound on Numpy version (numpy = ">=1.10.1,<2.0.0"). Ref #493. by @tompollard in #494
* Update actions to use actions/checkout@v3 and actions/setup-python@v4. by @tompollard in #495
* Fix: Indent code to ensure 'j' is within for-loop in GQRS algorithm by @tompollard in #499
* Add write_dir argument to csv_to_wfdb. Fixes #67. by @tompollard in #492
* Fix warnings by @cbrnr in #502
* README improvements by @bemoody in #503
* Change in type promotion. Fixes to annotation.py by @tompollard in #506
* Use uv by @cbrnr in #504
* Change in type promotion. Fixes to _signal.py by @tompollard in #507
* Test round-trip write/read of supported binary formats by @bemoody in #509
* Corrected typo and extended allowed types for MultiSegmentRecord by @agent3gatech in #514
* Allow expanded physical signal in `calc_adc_params` by @briangow in #512
* Add capability to write signal with unique `samps_per_frame` to `wfdb.io.wrsamp` by @briangow in #510
* Fix selection of channels when converting to EDF by @SamJelfs in #519
* Change in type promotion introduced in Numpy 2.0. Fixes to edf.py. by @tompollard in #527
* Bump dependencies for NumPy 2 compatibility by @cbrnr in #511
* Bump version to v4.2.0 and update notes on creating new releases by @tompollard in #497

## New Contributors

* @ajadczaksunriselabs made their first contribution in #459
* @tecamenz made their first contribution in #465
* @SnoopJ made their first contribution in #472
* @dependabot made their first contribution in #477
* @agent3gatech made their first contribution in #514
* @SamJelfs made their first contribution in #519

**Full Changelog**: v4.1.2...v4.2.0
```
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants