assign values to empty row in R












0














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.










share|improve this question






















  • 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
















0














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.










share|improve this question






















  • 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














0












0








0







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.










share|improve this question













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






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 14 '18 at 16:16









Forge

359316




359316












  • 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










  • 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












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
});


}
});














draft saved

draft discarded


















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
















draft saved

draft discarded




















































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.





Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


Please pay close attention to the following guidance:


  • 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.




draft saved


draft discarded














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





















































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







Popular posts from this blog

Guess what letter conforming each word

Run scheduled task as local user group (not BUILTIN)

Port of Spain