-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* added suggested solution for pretty_table after testing it and adding more comments * modified function so it doesn't just take numeric cols so it's more flexible added tests but still need to add more to them * changed the code to account for using the latest version of pretty_num * Improve pretty num (#89) (#90) * added nsmall args to pretty_num and comma_sep to allow formatting of decimals * amended the function so it takes multiple values * updated documenation * fixed the issue with negative dp being passed to nsmall * changed code for testing pretty_num * amended the documentation for comma_sep and changed expected_error to expect_equal in test_pretty_num * fixed the - dp args problem added nsmall to the documentation fixed the lintr styling and complexity errors * added extra tests to pretty_num * fixing formtting issues for lint testing * adding documentation, testing and extra comments for pretty_table an extra documentation line for pretty_num came up when running workflows * fixing the example for pretty_table by adding export * amended the documentation to pretty_table to remove refs to the cols just being numeric, add link to the function family and linked the pretty_num function * improved the documentation * changed function name added data frame test changed the no rows from a warning to a stop updated documentation * updated package version, gave details on what was changed in the news.md and added myself to ctb in the description file * fixed the bracket mistake in description, put nsmall is code format and updated documentations * updated the descriptions file so that i'm no longer stealing rich's academic code
- Loading branch information
Showing
10 changed files
with
297 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,15 +1,16 @@ | ||
Type: Package | ||
Package: dfeR | ||
Title: Common DfE R tasks | ||
Version: 0.5.1 | ||
Version: 0.6.0 | ||
Authors@R: c( | ||
person("Cam", "Race", , "[email protected]", role = c("aut", "cre")), | ||
person("Laura", "Selby", , "[email protected]", role = "aut"), | ||
person("Adam", "Robinson", role = "aut"), | ||
person("Jen", "Machin", , "[email protected]", role = "ctb"), | ||
person("Jake", "Tufts", , "[email protected]", role = "ctb"), | ||
person("Rich", "Bielby", , "[email protected]", role = "ctb", | ||
comment = c(ORCID = "0000-0001-9070-9969")) | ||
comment = c(ORCID = "0000-0001-9070-9969")), | ||
person("Menna", "Zayed", , "[email protected]", role = "ctb") | ||
) | ||
Description: This package contains R functions to allow DfE analysts to | ||
re-use code for common analytical tasks that are undertaken across the | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,107 @@ | ||
# testing pretty table | ||
# create data frame for testing | ||
df <- data.frame( | ||
a = c(2.589, -5.8937, "c"), | ||
b = c(11.19875, 45.6894, -78.4985), | ||
c = c("X", "Y", "Z") | ||
) | ||
|
||
|
||
test_that("prettifies tables", { | ||
expect_equal(pretty_num_table(df), data.frame( | ||
a = c("2.59", "-5.89", as.double(NA)), | ||
b = c("11.20", "45.69", "-78.50"), | ||
c = c(as.double(NA), as.double(NA), as.double(NA)) | ||
)) | ||
|
||
expect_equal( | ||
pretty_num_table(df, gbp = TRUE, exclude_columns = "c"), | ||
data.frame( | ||
a = c("£2.59", "-£5.89", as.double(NA)), | ||
b = c("£11.20", "£45.69", "-£78.50"), | ||
c = c("X", "Y", "Z") | ||
) | ||
) | ||
|
||
|
||
expect_equal( | ||
pretty_num_table(df, | ||
suffix = "%", dp = 1, nsmall = 2, | ||
exclude_columns = c("b", "c") | ||
), | ||
data.frame( | ||
a = c("2.60%", "-5.90%", as.double(NA)), | ||
b = c(11.19875, 45.6894, -78.4985), | ||
c = c("X", "Y", "Z") | ||
) | ||
) | ||
|
||
expect_equal( | ||
pretty_num_table(df, | ||
alt_na = "[z]", dp = -1, | ||
include_columns = c("a", "b") | ||
), | ||
data.frame( | ||
a = c("0", "-10", "[z]"), | ||
b = c("10", "50", "-80"), | ||
c = c("X", "Y", "Z") | ||
) | ||
) | ||
|
||
expect_equal( | ||
pretty_num_table(df, | ||
alt_na = "", dp = 2, | ||
prefix = "+/-", suffix = "g", include_columns = "a" | ||
), | ||
data.frame( | ||
a = c("+2.59g", "-5.89g", ""), | ||
b = c(11.19875, 45.6894, -78.4985), | ||
c = c("X", "Y", "Z") | ||
) | ||
) | ||
|
||
|
||
expect_equal( | ||
pretty_num_table(df, | ||
dp = 2, | ||
include_columns = "a", exclude_columns = "b" | ||
), | ||
data.frame( | ||
a = c("2.59", "-5.89", as.double(NA)), | ||
b = c(11.19875, 45.6894, -78.4985), | ||
c = c("X", "Y", "Z") | ||
) | ||
) | ||
}) | ||
|
||
# test empty data frame | ||
|
||
# create empty data frame for testing | ||
df <- data.frame( | ||
a = character(), | ||
b = character(), | ||
c = character() | ||
) | ||
|
||
test_that("pretty_num_table with empty data frames", { | ||
expect_error(pretty_num_table(df), "Data frame is empty or contains no rows.") | ||
}) | ||
|
||
# test non data frame objects | ||
|
||
test_that("test non data frames", { | ||
expect_error( | ||
pretty_num_table(1.12), | ||
"Data has the class numeric, data must be a data.frame object" | ||
) | ||
|
||
expect_error( | ||
pretty_num_table("a"), | ||
"Data has the class character, data must be a data.frame object" | ||
) | ||
|
||
expect_error( | ||
pretty_num_table(c("a", 1.2)), | ||
"Data has the class character, data must be a data.frame object" | ||
) | ||
}) |