assign values to empty row in R
I have a function that returns a data frame with more than 50 columns (one row).
This function is called inside a loop (lapply) so I get a list of dataframes one row each.
I initialize an empty dataframe at the very beginning in the function to be populated with the actual data returned by the process (short version here for testing)
df <- read.csv(text = "conn,pc,server,profile")
R> df
[1] conn pc server profile car id amount
<0 rows> (or 0-length row.names)
I would like to assign values to the row taking into account that the process sometimes does not return values for all columns.
Similar SO questions tend to rely on initializing data frame this way:
df <- data.frame("conn"= NA, "pc"= NA, "server"= NA, "profile" = NA)
but I don't want a row of NAs in case there's no value returned.
So in my function I tried first:
returned.conn.value <- 3 # assigned by hand for the sake of simplicity
df$conn <- returned.conn.value
Error in `$<-.data.frame`(`*tmp*`, conn, value = 3) :
replacement has 1 row, data has 0
So I discovered there's no way of adding value to a column inside an empty dataframe, but.....
df[1,1] <- 3
This, to my surprise, worked. But, I consider very ugly to assign values to columns by index, so I tried this:
grep("^conn$", colnames(df))
[1] 1
Uglier indeed, as it's forcing me to write the very same line for every column (instead of counting by hand, yes)
So, I'm afraid I took a dead road leading to nowhere.
is there any way of initialize an empty dataframe as it will allow me to do simple assignments as the one below with no issue?
df$conn <- 3
Any hint will be much appreciated.
r dataframe
add a comment |
I have a function that returns a data frame with more than 50 columns (one row).
This function is called inside a loop (lapply) so I get a list of dataframes one row each.
I initialize an empty dataframe at the very beginning in the function to be populated with the actual data returned by the process (short version here for testing)
df <- read.csv(text = "conn,pc,server,profile")
R> df
[1] conn pc server profile car id amount
<0 rows> (or 0-length row.names)
I would like to assign values to the row taking into account that the process sometimes does not return values for all columns.
Similar SO questions tend to rely on initializing data frame this way:
df <- data.frame("conn"= NA, "pc"= NA, "server"= NA, "profile" = NA)
but I don't want a row of NAs in case there's no value returned.
So in my function I tried first:
returned.conn.value <- 3 # assigned by hand for the sake of simplicity
df$conn <- returned.conn.value
Error in `$<-.data.frame`(`*tmp*`, conn, value = 3) :
replacement has 1 row, data has 0
So I discovered there's no way of adding value to a column inside an empty dataframe, but.....
df[1,1] <- 3
This, to my surprise, worked. But, I consider very ugly to assign values to columns by index, so I tried this:
grep("^conn$", colnames(df))
[1] 1
Uglier indeed, as it's forcing me to write the very same line for every column (instead of counting by hand, yes)
So, I'm afraid I took a dead road leading to nowhere.
is there any way of initialize an empty dataframe as it will allow me to do simple assignments as the one below with no issue?
df$conn <- 3
Any hint will be much appreciated.
r dataframe
I don't know how to do this inside of an empty data.frame, but you could do it inside separate vectors and cbind them at the end?
– Adam K
Nov 14 '18 at 17:35
Not really. The data flow only allows me to get a data frame every time the function is called. I can’t imagine how to gather results into vectors and then cbind....
– Forge
Nov 14 '18 at 18:24
add a comment |
I have a function that returns a data frame with more than 50 columns (one row).
This function is called inside a loop (lapply) so I get a list of dataframes one row each.
I initialize an empty dataframe at the very beginning in the function to be populated with the actual data returned by the process (short version here for testing)
df <- read.csv(text = "conn,pc,server,profile")
R> df
[1] conn pc server profile car id amount
<0 rows> (or 0-length row.names)
I would like to assign values to the row taking into account that the process sometimes does not return values for all columns.
Similar SO questions tend to rely on initializing data frame this way:
df <- data.frame("conn"= NA, "pc"= NA, "server"= NA, "profile" = NA)
but I don't want a row of NAs in case there's no value returned.
So in my function I tried first:
returned.conn.value <- 3 # assigned by hand for the sake of simplicity
df$conn <- returned.conn.value
Error in `$<-.data.frame`(`*tmp*`, conn, value = 3) :
replacement has 1 row, data has 0
So I discovered there's no way of adding value to a column inside an empty dataframe, but.....
df[1,1] <- 3
This, to my surprise, worked. But, I consider very ugly to assign values to columns by index, so I tried this:
grep("^conn$", colnames(df))
[1] 1
Uglier indeed, as it's forcing me to write the very same line for every column (instead of counting by hand, yes)
So, I'm afraid I took a dead road leading to nowhere.
is there any way of initialize an empty dataframe as it will allow me to do simple assignments as the one below with no issue?
df$conn <- 3
Any hint will be much appreciated.
r dataframe
I have a function that returns a data frame with more than 50 columns (one row).
This function is called inside a loop (lapply) so I get a list of dataframes one row each.
I initialize an empty dataframe at the very beginning in the function to be populated with the actual data returned by the process (short version here for testing)
df <- read.csv(text = "conn,pc,server,profile")
R> df
[1] conn pc server profile car id amount
<0 rows> (or 0-length row.names)
I would like to assign values to the row taking into account that the process sometimes does not return values for all columns.
Similar SO questions tend to rely on initializing data frame this way:
df <- data.frame("conn"= NA, "pc"= NA, "server"= NA, "profile" = NA)
but I don't want a row of NAs in case there's no value returned.
So in my function I tried first:
returned.conn.value <- 3 # assigned by hand for the sake of simplicity
df$conn <- returned.conn.value
Error in `$<-.data.frame`(`*tmp*`, conn, value = 3) :
replacement has 1 row, data has 0
So I discovered there's no way of adding value to a column inside an empty dataframe, but.....
df[1,1] <- 3
This, to my surprise, worked. But, I consider very ugly to assign values to columns by index, so I tried this:
grep("^conn$", colnames(df))
[1] 1
Uglier indeed, as it's forcing me to write the very same line for every column (instead of counting by hand, yes)
So, I'm afraid I took a dead road leading to nowhere.
is there any way of initialize an empty dataframe as it will allow me to do simple assignments as the one below with no issue?
df$conn <- 3
Any hint will be much appreciated.
r dataframe
r dataframe
asked Nov 14 '18 at 16:16
ForgeForge
374316
374316
I don't know how to do this inside of an empty data.frame, but you could do it inside separate vectors and cbind them at the end?
– Adam K
Nov 14 '18 at 17:35
Not really. The data flow only allows me to get a data frame every time the function is called. I can’t imagine how to gather results into vectors and then cbind....
– Forge
Nov 14 '18 at 18:24
add a comment |
I don't know how to do this inside of an empty data.frame, but you could do it inside separate vectors and cbind them at the end?
– Adam K
Nov 14 '18 at 17:35
Not really. The data flow only allows me to get a data frame every time the function is called. I can’t imagine how to gather results into vectors and then cbind....
– Forge
Nov 14 '18 at 18:24
I don't know how to do this inside of an empty data.frame, but you could do it inside separate vectors and cbind them at the end?
– Adam K
Nov 14 '18 at 17:35
I don't know how to do this inside of an empty data.frame, but you could do it inside separate vectors and cbind them at the end?
– Adam K
Nov 14 '18 at 17:35
Not really. The data flow only allows me to get a data frame every time the function is called. I can’t imagine how to gather results into vectors and then cbind....
– Forge
Nov 14 '18 at 18:24
Not really. The data flow only allows me to get a data frame every time the function is called. I can’t imagine how to gather results into vectors and then cbind....
– Forge
Nov 14 '18 at 18:24
add a comment |
0
active
oldest
votes
Your Answer
StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");
StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);
else
createEditor();
);
function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53304537%2fassign-values-to-empty-row-in-r%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
0
active
oldest
votes
0
active
oldest
votes
active
oldest
votes
active
oldest
votes
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53304537%2fassign-values-to-empty-row-in-r%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
I don't know how to do this inside of an empty data.frame, but you could do it inside separate vectors and cbind them at the end?
– Adam K
Nov 14 '18 at 17:35
Not really. The data flow only allows me to get a data frame every time the function is called. I can’t imagine how to gather results into vectors and then cbind....
– Forge
Nov 14 '18 at 18:24