How to create variables in a data frame based on existing variables in a for loop
I have a data frame that has a number of variables in it that I want to concatenate into new variables in that same data frame. A simplified version of my data frame df looks like this:
first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113
Here is how I do it inefficiently without a for loop:
df$concatenated.1 <- paste0(df$first.1,"-",df$second.1)
df$concatenated.2 <- paste0(df$first.2,"-",df$second.2)
Which results in the following data frame df:
first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
1222 3223 3333 1221 1222-3223 3333-1221
1111 2212 2232 2113 1111-2212 2232-2113
I have a lot more than 2 pairs of variables to concatenate, so I would like to do this in a for loop:
for (i in 1:2){
??
}
Any ideas on how to accomplish this?
r for-loop
add a comment |
I have a data frame that has a number of variables in it that I want to concatenate into new variables in that same data frame. A simplified version of my data frame df looks like this:
first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113
Here is how I do it inefficiently without a for loop:
df$concatenated.1 <- paste0(df$first.1,"-",df$second.1)
df$concatenated.2 <- paste0(df$first.2,"-",df$second.2)
Which results in the following data frame df:
first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
1222 3223 3333 1221 1222-3223 3333-1221
1111 2212 2232 2113 1111-2212 2232-2113
I have a lot more than 2 pairs of variables to concatenate, so I would like to do this in a for loop:
for (i in 1:2){
??
}
Any ideas on how to accomplish this?
r for-loop
If i got your question. here you can find a proper answer stackoverflow.com/questions/18115550/…
– simin
4 hours ago
add a comment |
I have a data frame that has a number of variables in it that I want to concatenate into new variables in that same data frame. A simplified version of my data frame df looks like this:
first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113
Here is how I do it inefficiently without a for loop:
df$concatenated.1 <- paste0(df$first.1,"-",df$second.1)
df$concatenated.2 <- paste0(df$first.2,"-",df$second.2)
Which results in the following data frame df:
first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
1222 3223 3333 1221 1222-3223 3333-1221
1111 2212 2232 2113 1111-2212 2232-2113
I have a lot more than 2 pairs of variables to concatenate, so I would like to do this in a for loop:
for (i in 1:2){
??
}
Any ideas on how to accomplish this?
r for-loop
I have a data frame that has a number of variables in it that I want to concatenate into new variables in that same data frame. A simplified version of my data frame df looks like this:
first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113
Here is how I do it inefficiently without a for loop:
df$concatenated.1 <- paste0(df$first.1,"-",df$second.1)
df$concatenated.2 <- paste0(df$first.2,"-",df$second.2)
Which results in the following data frame df:
first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
1222 3223 3333 1221 1222-3223 3333-1221
1111 2212 2232 2113 1111-2212 2232-2113
I have a lot more than 2 pairs of variables to concatenate, so I would like to do this in a for loop:
for (i in 1:2){
??
}
Any ideas on how to accomplish this?
r for-loop
r for-loop
edited 4 hours ago
Uwe Keim
27.4k31128210
27.4k31128210
asked 4 hours ago
Abdel
1,96483857
1,96483857
If i got your question. here you can find a proper answer stackoverflow.com/questions/18115550/…
– simin
4 hours ago
add a comment |
If i got your question. here you can find a proper answer stackoverflow.com/questions/18115550/…
– simin
4 hours ago
If i got your question. here you can find a proper answer stackoverflow.com/questions/18115550/…
– simin
4 hours ago
If i got your question. here you can find a proper answer stackoverflow.com/questions/18115550/…
– simin
4 hours ago
add a comment |
5 Answers
5
active
oldest
votes
If your real data has names which follow a clear pattern as in this example data, Ronak's split
/ lapply
answer is probably best. If not, you can just create vectors of the names and use Map
with paste
.
new.names <- paste0('concatenated.', 1:2)
names.1 <- paste0('first.', 1:2)
names.2 <- paste0('second.', 1:2)
df[new.names] <- Map(paste, df[names.1], df[names.2], sep = '-')
df
# first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
# 1 1222 3223 3333 1221 1222-3223 3333-1221
# 2 1111 2212 2232 2113 1111-2212 2232-2113
add a comment |
If you could figure out a way to split your columns then it would be much easier. For example, based on provided example we can split columns based on last characters of column names (1, 1, 2, 2).
Using base R we use split.default
to split the columns based on names (as described above) and for every group we paste
each row and add new columns.
group_names <- substring(names(df), nchar(names(df)))
df[paste0("concatenated.", unique(group_names))] <-
lapply(split.default(df,group_names), function(x) do.call(paste, c(x, sep = "-")))
df
# first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
#1 1222 3223 3333 1221 1222-3223 3333-1221
#2 1111 2212 2232 2113 1111-2212 2232-2113
add a comment |
Here's a tidyverse solution that gets you most of the way there. The only difference is that the columns are output alphabetically, i.e., the "firsts", then the "concatenated"s, then the "seconds".
txt <- 'first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113'
df <- read.table(text = txt, header = T)
library(tidyverse)
df2 <- df %>%
mutate(row.num = row_number()) %>%
gather(variable, value, -row.num) %>%
separate(variable, into = c('order', 'pair')) %>%
spread(order, value) %>%
mutate(concatenated = paste0(first, '-', second)) %>%
gather(variable, value, -row.num, -pair) %>%
unite(name, variable, pair) %>%
spread(name, value)
row.num concatenated_1 concatenated_2 first_1 first_2 second_1 second_2
1 1 1222-3223 3333-1221 1222 3333 3223 1221
2 2 1111-2212 2232-2113 1111 2232 2212 2113
add a comment |
library(tidyverse)
[EDITED: original solution incorrectly used starts_with
]
This solution uses ends_with()
to select the appropriate columns, then unite
to combine them with a -
seperator:
df <- tribble(
~first.1, ~second.1, ~first.2, ~second.2,
1222,3223,3333,1221,
1111,2212,2232,2113)
df1 <- df %>%
select(ends_with("1")) %>%
unite(concatenated.1, sep = "-")
df2 <- df %>%
select(ends_with("2")) %>%
unite(concatenated.2, sep = "-")
cbind(df, df1, df2)
@IceCreamToucan you're right. I changed the function toends_with
... I think that fixes it to the OP's request
– Marian Minar
3 hours ago
add a comment |
you can use the function stri_join
in the stringi package, which is very fast.
library(data.table)
library(stringi)
df <- fread("first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113")
cols <- paste0("concatenated_", 1:2)
df[, (cols) := Map(stri_join, .(first.1, first.2), .(second.1, second.2), sep = "-")]
setDF(df)
first.1 second.1 first.2 second.2 concatenated_1 concatenated_2
1 1222 3223 3333 1221 1222-3223 3333-1221
2 1111 2212 2232 2113 1111-2212 2232-2113
New contributor
add a comment |
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%2f53978785%2fhow-to-create-variables-in-a-data-frame-based-on-existing-variables-in-a-for-loo%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
5 Answers
5
active
oldest
votes
5 Answers
5
active
oldest
votes
active
oldest
votes
active
oldest
votes
If your real data has names which follow a clear pattern as in this example data, Ronak's split
/ lapply
answer is probably best. If not, you can just create vectors of the names and use Map
with paste
.
new.names <- paste0('concatenated.', 1:2)
names.1 <- paste0('first.', 1:2)
names.2 <- paste0('second.', 1:2)
df[new.names] <- Map(paste, df[names.1], df[names.2], sep = '-')
df
# first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
# 1 1222 3223 3333 1221 1222-3223 3333-1221
# 2 1111 2212 2232 2113 1111-2212 2232-2113
add a comment |
If your real data has names which follow a clear pattern as in this example data, Ronak's split
/ lapply
answer is probably best. If not, you can just create vectors of the names and use Map
with paste
.
new.names <- paste0('concatenated.', 1:2)
names.1 <- paste0('first.', 1:2)
names.2 <- paste0('second.', 1:2)
df[new.names] <- Map(paste, df[names.1], df[names.2], sep = '-')
df
# first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
# 1 1222 3223 3333 1221 1222-3223 3333-1221
# 2 1111 2212 2232 2113 1111-2212 2232-2113
add a comment |
If your real data has names which follow a clear pattern as in this example data, Ronak's split
/ lapply
answer is probably best. If not, you can just create vectors of the names and use Map
with paste
.
new.names <- paste0('concatenated.', 1:2)
names.1 <- paste0('first.', 1:2)
names.2 <- paste0('second.', 1:2)
df[new.names] <- Map(paste, df[names.1], df[names.2], sep = '-')
df
# first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
# 1 1222 3223 3333 1221 1222-3223 3333-1221
# 2 1111 2212 2232 2113 1111-2212 2232-2113
If your real data has names which follow a clear pattern as in this example data, Ronak's split
/ lapply
answer is probably best. If not, you can just create vectors of the names and use Map
with paste
.
new.names <- paste0('concatenated.', 1:2)
names.1 <- paste0('first.', 1:2)
names.2 <- paste0('second.', 1:2)
df[new.names] <- Map(paste, df[names.1], df[names.2], sep = '-')
df
# first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
# 1 1222 3223 3333 1221 1222-3223 3333-1221
# 2 1111 2212 2232 2113 1111-2212 2232-2113
edited 3 hours ago
answered 4 hours ago
IceCreamToucan
8,8301716
8,8301716
add a comment |
add a comment |
If you could figure out a way to split your columns then it would be much easier. For example, based on provided example we can split columns based on last characters of column names (1, 1, 2, 2).
Using base R we use split.default
to split the columns based on names (as described above) and for every group we paste
each row and add new columns.
group_names <- substring(names(df), nchar(names(df)))
df[paste0("concatenated.", unique(group_names))] <-
lapply(split.default(df,group_names), function(x) do.call(paste, c(x, sep = "-")))
df
# first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
#1 1222 3223 3333 1221 1222-3223 3333-1221
#2 1111 2212 2232 2113 1111-2212 2232-2113
add a comment |
If you could figure out a way to split your columns then it would be much easier. For example, based on provided example we can split columns based on last characters of column names (1, 1, 2, 2).
Using base R we use split.default
to split the columns based on names (as described above) and for every group we paste
each row and add new columns.
group_names <- substring(names(df), nchar(names(df)))
df[paste0("concatenated.", unique(group_names))] <-
lapply(split.default(df,group_names), function(x) do.call(paste, c(x, sep = "-")))
df
# first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
#1 1222 3223 3333 1221 1222-3223 3333-1221
#2 1111 2212 2232 2113 1111-2212 2232-2113
add a comment |
If you could figure out a way to split your columns then it would be much easier. For example, based on provided example we can split columns based on last characters of column names (1, 1, 2, 2).
Using base R we use split.default
to split the columns based on names (as described above) and for every group we paste
each row and add new columns.
group_names <- substring(names(df), nchar(names(df)))
df[paste0("concatenated.", unique(group_names))] <-
lapply(split.default(df,group_names), function(x) do.call(paste, c(x, sep = "-")))
df
# first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
#1 1222 3223 3333 1221 1222-3223 3333-1221
#2 1111 2212 2232 2113 1111-2212 2232-2113
If you could figure out a way to split your columns then it would be much easier. For example, based on provided example we can split columns based on last characters of column names (1, 1, 2, 2).
Using base R we use split.default
to split the columns based on names (as described above) and for every group we paste
each row and add new columns.
group_names <- substring(names(df), nchar(names(df)))
df[paste0("concatenated.", unique(group_names))] <-
lapply(split.default(df,group_names), function(x) do.call(paste, c(x, sep = "-")))
df
# first.1 second.1 first.2 second.2 concatenated.1 concatenated.2
#1 1222 3223 3333 1221 1222-3223 3333-1221
#2 1111 2212 2232 2113 1111-2212 2232-2113
answered 4 hours ago
Ronak Shah
32.2k103753
32.2k103753
add a comment |
add a comment |
Here's a tidyverse solution that gets you most of the way there. The only difference is that the columns are output alphabetically, i.e., the "firsts", then the "concatenated"s, then the "seconds".
txt <- 'first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113'
df <- read.table(text = txt, header = T)
library(tidyverse)
df2 <- df %>%
mutate(row.num = row_number()) %>%
gather(variable, value, -row.num) %>%
separate(variable, into = c('order', 'pair')) %>%
spread(order, value) %>%
mutate(concatenated = paste0(first, '-', second)) %>%
gather(variable, value, -row.num, -pair) %>%
unite(name, variable, pair) %>%
spread(name, value)
row.num concatenated_1 concatenated_2 first_1 first_2 second_1 second_2
1 1 1222-3223 3333-1221 1222 3333 3223 1221
2 2 1111-2212 2232-2113 1111 2232 2212 2113
add a comment |
Here's a tidyverse solution that gets you most of the way there. The only difference is that the columns are output alphabetically, i.e., the "firsts", then the "concatenated"s, then the "seconds".
txt <- 'first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113'
df <- read.table(text = txt, header = T)
library(tidyverse)
df2 <- df %>%
mutate(row.num = row_number()) %>%
gather(variable, value, -row.num) %>%
separate(variable, into = c('order', 'pair')) %>%
spread(order, value) %>%
mutate(concatenated = paste0(first, '-', second)) %>%
gather(variable, value, -row.num, -pair) %>%
unite(name, variable, pair) %>%
spread(name, value)
row.num concatenated_1 concatenated_2 first_1 first_2 second_1 second_2
1 1 1222-3223 3333-1221 1222 3333 3223 1221
2 2 1111-2212 2232-2113 1111 2232 2212 2113
add a comment |
Here's a tidyverse solution that gets you most of the way there. The only difference is that the columns are output alphabetically, i.e., the "firsts", then the "concatenated"s, then the "seconds".
txt <- 'first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113'
df <- read.table(text = txt, header = T)
library(tidyverse)
df2 <- df %>%
mutate(row.num = row_number()) %>%
gather(variable, value, -row.num) %>%
separate(variable, into = c('order', 'pair')) %>%
spread(order, value) %>%
mutate(concatenated = paste0(first, '-', second)) %>%
gather(variable, value, -row.num, -pair) %>%
unite(name, variable, pair) %>%
spread(name, value)
row.num concatenated_1 concatenated_2 first_1 first_2 second_1 second_2
1 1 1222-3223 3333-1221 1222 3333 3223 1221
2 2 1111-2212 2232-2113 1111 2232 2212 2113
Here's a tidyverse solution that gets you most of the way there. The only difference is that the columns are output alphabetically, i.e., the "firsts", then the "concatenated"s, then the "seconds".
txt <- 'first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113'
df <- read.table(text = txt, header = T)
library(tidyverse)
df2 <- df %>%
mutate(row.num = row_number()) %>%
gather(variable, value, -row.num) %>%
separate(variable, into = c('order', 'pair')) %>%
spread(order, value) %>%
mutate(concatenated = paste0(first, '-', second)) %>%
gather(variable, value, -row.num, -pair) %>%
unite(name, variable, pair) %>%
spread(name, value)
row.num concatenated_1 concatenated_2 first_1 first_2 second_1 second_2
1 1 1222-3223 3333-1221 1222 3333 3223 1221
2 2 1111-2212 2232-2113 1111 2232 2212 2113
answered 4 hours ago
jdobres
4,6251522
4,6251522
add a comment |
add a comment |
library(tidyverse)
[EDITED: original solution incorrectly used starts_with
]
This solution uses ends_with()
to select the appropriate columns, then unite
to combine them with a -
seperator:
df <- tribble(
~first.1, ~second.1, ~first.2, ~second.2,
1222,3223,3333,1221,
1111,2212,2232,2113)
df1 <- df %>%
select(ends_with("1")) %>%
unite(concatenated.1, sep = "-")
df2 <- df %>%
select(ends_with("2")) %>%
unite(concatenated.2, sep = "-")
cbind(df, df1, df2)
@IceCreamToucan you're right. I changed the function toends_with
... I think that fixes it to the OP's request
– Marian Minar
3 hours ago
add a comment |
library(tidyverse)
[EDITED: original solution incorrectly used starts_with
]
This solution uses ends_with()
to select the appropriate columns, then unite
to combine them with a -
seperator:
df <- tribble(
~first.1, ~second.1, ~first.2, ~second.2,
1222,3223,3333,1221,
1111,2212,2232,2113)
df1 <- df %>%
select(ends_with("1")) %>%
unite(concatenated.1, sep = "-")
df2 <- df %>%
select(ends_with("2")) %>%
unite(concatenated.2, sep = "-")
cbind(df, df1, df2)
@IceCreamToucan you're right. I changed the function toends_with
... I think that fixes it to the OP's request
– Marian Minar
3 hours ago
add a comment |
library(tidyverse)
[EDITED: original solution incorrectly used starts_with
]
This solution uses ends_with()
to select the appropriate columns, then unite
to combine them with a -
seperator:
df <- tribble(
~first.1, ~second.1, ~first.2, ~second.2,
1222,3223,3333,1221,
1111,2212,2232,2113)
df1 <- df %>%
select(ends_with("1")) %>%
unite(concatenated.1, sep = "-")
df2 <- df %>%
select(ends_with("2")) %>%
unite(concatenated.2, sep = "-")
cbind(df, df1, df2)
library(tidyverse)
[EDITED: original solution incorrectly used starts_with
]
This solution uses ends_with()
to select the appropriate columns, then unite
to combine them with a -
seperator:
df <- tribble(
~first.1, ~second.1, ~first.2, ~second.2,
1222,3223,3333,1221,
1111,2212,2232,2113)
df1 <- df %>%
select(ends_with("1")) %>%
unite(concatenated.1, sep = "-")
df2 <- df %>%
select(ends_with("2")) %>%
unite(concatenated.2, sep = "-")
cbind(df, df1, df2)
edited 3 hours ago
answered 3 hours ago
Marian Minar
2266
2266
@IceCreamToucan you're right. I changed the function toends_with
... I think that fixes it to the OP's request
– Marian Minar
3 hours ago
add a comment |
@IceCreamToucan you're right. I changed the function toends_with
... I think that fixes it to the OP's request
– Marian Minar
3 hours ago
@IceCreamToucan you're right. I changed the function to
ends_with
... I think that fixes it to the OP's request– Marian Minar
3 hours ago
@IceCreamToucan you're right. I changed the function to
ends_with
... I think that fixes it to the OP's request– Marian Minar
3 hours ago
add a comment |
you can use the function stri_join
in the stringi package, which is very fast.
library(data.table)
library(stringi)
df <- fread("first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113")
cols <- paste0("concatenated_", 1:2)
df[, (cols) := Map(stri_join, .(first.1, first.2), .(second.1, second.2), sep = "-")]
setDF(df)
first.1 second.1 first.2 second.2 concatenated_1 concatenated_2
1 1222 3223 3333 1221 1222-3223 3333-1221
2 1111 2212 2232 2113 1111-2212 2232-2113
New contributor
add a comment |
you can use the function stri_join
in the stringi package, which is very fast.
library(data.table)
library(stringi)
df <- fread("first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113")
cols <- paste0("concatenated_", 1:2)
df[, (cols) := Map(stri_join, .(first.1, first.2), .(second.1, second.2), sep = "-")]
setDF(df)
first.1 second.1 first.2 second.2 concatenated_1 concatenated_2
1 1222 3223 3333 1221 1222-3223 3333-1221
2 1111 2212 2232 2113 1111-2212 2232-2113
New contributor
add a comment |
you can use the function stri_join
in the stringi package, which is very fast.
library(data.table)
library(stringi)
df <- fread("first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113")
cols <- paste0("concatenated_", 1:2)
df[, (cols) := Map(stri_join, .(first.1, first.2), .(second.1, second.2), sep = "-")]
setDF(df)
first.1 second.1 first.2 second.2 concatenated_1 concatenated_2
1 1222 3223 3333 1221 1222-3223 3333-1221
2 1111 2212 2232 2113 1111-2212 2232-2113
New contributor
you can use the function stri_join
in the stringi package, which is very fast.
library(data.table)
library(stringi)
df <- fread("first.1 second.1 first.2 second.2
1222 3223 3333 1221
1111 2212 2232 2113")
cols <- paste0("concatenated_", 1:2)
df[, (cols) := Map(stri_join, .(first.1, first.2), .(second.1, second.2), sep = "-")]
setDF(df)
first.1 second.1 first.2 second.2 concatenated_1 concatenated_2
1 1222 3223 3333 1221 1222-3223 3333-1221
2 1111 2212 2232 2113 1111-2212 2232-2113
New contributor
edited 2 hours ago
New contributor
answered 2 hours ago
B. Christian Kamgang
112
112
New contributor
New contributor
add a comment |
add a comment |
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.
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%2f53978785%2fhow-to-create-variables-in-a-data-frame-based-on-existing-variables-in-a-for-loo%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
If i got your question. here you can find a proper answer stackoverflow.com/questions/18115550/…
– simin
4 hours ago