Concatenate pairs of variables with same suffix












7














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?










share|improve this question
























  • If i got your question. here you can find a proper answer stackoverflow.com/questions/18115550/…
    – simin
    11 hours ago
















7














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?










share|improve this question
























  • If i got your question. here you can find a proper answer stackoverflow.com/questions/18115550/…
    – simin
    11 hours ago














7












7








7







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?










share|improve this question















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






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited 3 hours ago









Henrik

40.7k992107




40.7k992107










asked 11 hours ago









Abdel

1,96483857




1,96483857












  • If i got your question. here you can find a proper answer stackoverflow.com/questions/18115550/…
    – simin
    11 hours ago


















  • If i got your question. here you can find a proper answer stackoverflow.com/questions/18115550/…
    – simin
    11 hours ago
















If i got your question. here you can find a proper answer stackoverflow.com/questions/18115550/…
– simin
11 hours ago




If i got your question. here you can find a proper answer stackoverflow.com/questions/18115550/…
– simin
11 hours ago












5 Answers
5






active

oldest

votes


















3














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





share|improve this answer































    3














    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





    share|improve this answer





























      2














      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





      share|improve this answer





























        2














        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)





        share|improve this answer























        • @IceCreamToucan you're right. I changed the function to ends_with ... I think that fixes it to the OP's request
          – Marian Minar
          10 hours ago



















        1














        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





        share|improve this answer










        New contributor




        B. Christian Kamgang is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
        Check out our Code of Conduct.


















          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%2f53978785%2fconcatenate-pairs-of-variables-with-same-suffix%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









          3














          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





          share|improve this answer




























            3














            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





            share|improve this answer


























              3












              3








              3






              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





              share|improve this answer














              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






              share|improve this answer














              share|improve this answer



              share|improve this answer








              edited 10 hours ago

























              answered 11 hours ago









              IceCreamToucan

              8,8301716




              8,8301716

























                  3














                  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





                  share|improve this answer


























                    3














                    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





                    share|improve this answer
























                      3












                      3








                      3






                      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





                      share|improve this answer












                      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






                      share|improve this answer












                      share|improve this answer



                      share|improve this answer










                      answered 11 hours ago









                      Ronak Shah

                      32.2k103753




                      32.2k103753























                          2














                          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





                          share|improve this answer


























                            2














                            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





                            share|improve this answer
























                              2












                              2








                              2






                              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





                              share|improve this answer












                              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






                              share|improve this answer












                              share|improve this answer



                              share|improve this answer










                              answered 11 hours ago









                              jdobres

                              4,6251522




                              4,6251522























                                  2














                                  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)





                                  share|improve this answer























                                  • @IceCreamToucan you're right. I changed the function to ends_with ... I think that fixes it to the OP's request
                                    – Marian Minar
                                    10 hours ago
















                                  2














                                  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)





                                  share|improve this answer























                                  • @IceCreamToucan you're right. I changed the function to ends_with ... I think that fixes it to the OP's request
                                    – Marian Minar
                                    10 hours ago














                                  2












                                  2








                                  2






                                  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)





                                  share|improve this answer














                                  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)






                                  share|improve this answer














                                  share|improve this answer



                                  share|improve this answer








                                  edited 10 hours ago

























                                  answered 10 hours ago









                                  Marian Minar

                                  2266




                                  2266












                                  • @IceCreamToucan you're right. I changed the function to ends_with ... I think that fixes it to the OP's request
                                    – Marian Minar
                                    10 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
                                    10 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
                                  10 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
                                  10 hours ago











                                  1














                                  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





                                  share|improve this answer










                                  New contributor




                                  B. Christian Kamgang is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                  Check out our Code of Conduct.























                                    1














                                    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





                                    share|improve this answer










                                    New contributor




                                    B. Christian Kamgang is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                    Check out our Code of Conduct.





















                                      1












                                      1








                                      1






                                      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





                                      share|improve this answer










                                      New contributor




                                      B. Christian Kamgang is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                      Check out our Code of Conduct.









                                      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






                                      share|improve this answer










                                      New contributor




                                      B. Christian Kamgang is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                      Check out our Code of Conduct.









                                      share|improve this answer



                                      share|improve this answer








                                      edited 9 hours ago





















                                      New contributor




                                      B. Christian Kamgang is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                      Check out our Code of Conduct.









                                      answered 9 hours ago









                                      B. Christian Kamgang

                                      112




                                      112




                                      New contributor




                                      B. Christian Kamgang is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                      Check out our Code of Conduct.





                                      New contributor





                                      B. Christian Kamgang is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                      Check out our Code of Conduct.






                                      B. Christian Kamgang is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                      Check out our Code of Conduct.






























                                          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%2f53978785%2fconcatenate-pairs-of-variables-with-same-suffix%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

                                          Morgemoulin

                                          Scott Moir

                                          Souastre