Я работаю над кодом для пакетной обработки таблиц Excel для импорта в реляционную базу данных.Каждый лист Excel представляет данные для разных семей слонов, с набором особей и их присутствием / отсутствием в разные даты.Мне нужно, чтобы это был обобщенный код, потому что у меня есть 50+ листов для каждого года и> 10 лет для импорта.
Количество людей в семье варьируется, равно как и число дат, которые они наблюдали.Мне нужно переставить каждый элемент tibble, чтобы я мог заменить 1 единицами на отдельные коды (уже были получены ответы в StackOverflow), которые я затем могу повторно собрать в один список для каждого семейства, как показано ниже.
Данныев настоящее время в Excel;
Ind Date1 Date2 Date3 Date4
A 1 1 1
B 1 1
C 1 1
D 1 1
И я пытаюсь получить его;
Date1 A
Date1 B
Date1 C
Date1 D
Date2 A
Date2 B
Date3 C
Date3 D
Date4 A
Я думаю, мне нужен цикл for, чтобы сделать это, потому что каждый элемент варьируется по длине,поэтому все мои усилия с map * () collect () или t () потерпели неудачу.
«mysheets» - это список из 50 элементов, по одному на каждое семейство, самый большой из которых - 60 строк и 93колонны;пример
dput (head (mysheets, 4))
'list(AA = structure(list(Date = c("Famsize", "Grpsize", "ALY68",
"AME16", "AME12", "AME99", "AME90", "ANN12", "ANN03", "ALF16",
"AME81", "ANH16", "ANH11", "ALI79", "AST97", "ALI98", "ART14",
"ART10", "ALI02", "ARD13", "ALI12", "AGA82", "ALT14", "ALT02",
"AGA93", "ALX15", "ALX11", "AMY85", "ANG15", "ANG11", "AMB10",
"AUD94", "ABR12", "ART17"), `42761` = c(4, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, 1, 1, 1, 1, NA, NA, NA), `42767` = c(12,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, 1,
1, 1, 1, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, NA, NA, NA), `42770` = c(15,
NA, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, NA, NA, 1, 1, 1, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, NA), `42773` = c(20,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, NA), `42777` = c(6,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, 1, 1, NA),
`42782` = c(6, 7, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, 1, 1, NA,
NA, NA, NA, NA, NA, NA), `42802...8` = c(6, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, 1, 1, NA), `42802...9` = c(8,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1,
1, 1, 1, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA), `42809` = c(3, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, 1, 1, 1, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA), `42816` = c(22, NA,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, NA, NA, NA, 1, 1,
1, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, 1, 1, NA), `42850...12` = c(8,
NA, 1, 1, 1, 1, NA, NA, NA, 1, 1, 1, 1, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA), `42850...13` = c(14, 16, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, 1, 1, 1, 1, 1, 1, 1, 1, NA, NA, NA, NA, NA,
NA, 1, 1, 1, 1, 1, 1, NA), `42859` = c(2, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
`42860...15` = c(2, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, 1, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA), `42860...16` = c(6, 14,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, NA, 1, 1,
NA), `42862` = c(8, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, 1, 1, NA, NA, NA, 1, 1, 1, NA, NA, NA, NA, NA, NA,
NA, NA, NA, 1, 1, 1, NA), `42864` = c(3, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, NA, NA, NA, NA), `42866` = c(6,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1,
1, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, NA, NA,
NA, NA), `42870` = c(8, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, 1, NA, NA, NA, 1, 1, 1, 1, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, 1, 1, NA), `42880` = c(6, 11, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, NA, 1, 1, 1, NA, NA,
1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA), `42784...22` = c(8,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1,
1, 1, 1, 1, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA), `42784...23` = c(2, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, NA), `42823` = c(8,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1,
1, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, NA, 1,
1, NA), `42817` = c(6, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, 1,
1, NA, NA, NA, NA, NA, NA, NA), `42896` = c(6, 16, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, 1, 1, NA), `42933...27` = c(14,
27, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1,
1, 1, 1, 1, 1, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, 1, 1,
NA), `43057` = c(7, NA, NA, NA, NA, 1, 1, 1, 1, NA, 1, NA,
1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA), `43082` = c(7, NA, NA, NA, NA,
1, 1, 1, 1, NA, 1, NA, 1, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA), `42928` = c(7,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, NA, NA,
NA, NA, 1, 1, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1,
1, NA), `42933...31` = c(11, 24, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, 1, 1, NA, NA, NA, 1, 1, 1, NA, NA, NA,
NA, NA, NA, 1, 1, 1, 1, 1, 1, NA), `42935...32` = c(3, 21,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1,
1, NA), `42935...33` = c(4, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, 1, 1, 1, 1, NA, NA, NA), `42936` = c(11, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, NA, NA,
NA, 1, 1, 1, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, 1, 1, NA
), `42949...35` = c(4, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, 1, 1, NA), `42949...36` = c(3, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1,
1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA), `42952` = c(2, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA), `43319` = c(5, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, NA, 1, 1, NA
), `42959...39` = c(6, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, 1,
1, NA, NA, NA, NA, NA, NA, NA), `42959...40` = c(10, NA,
1, NA, 1, 1, 1, 1, 1, 1, 1, 1, 1, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA
), `42966` = c(4, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, 1, 1, 1, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, 1, NA, NA, NA), `42978` = c(10, NA, 1, NA,
1, 1, 1, 1, 1, 1, 1, 1, 1, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA), `42986` = c(2,
NA, 1, NA, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA), `42992...44` = c(6, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, 1, 1, 1, 1, 1, 1, NA), `42992...45` = c(3,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1,
1, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA), `42997` = c(6, 10, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1,
1, 1, 1, NA, NA, NA, NA, NA, NA, NA), `43007` = c(3, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, NA, NA,
NA, NA, NA, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA), `43015` = c(6, 7, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, NA, 1, 1, 1,
1, NA, NA, NA, NA, NA, NA, NA), `43046` = c(3, 14, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, NA, NA, NA, NA),
`41222` = c(3, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1,
NA, NA, NA, NA, NA, NA, NA), `43048...51` = c(5, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, 1, 1, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, NA, NA, NA
), `43048...52` = c(3, 7, NA, NA, 1, NA, NA, NA, NA, NA,
1, NA, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA), `43054` = c(5, 10, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
1, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, NA
), `43068` = c(3, 6, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, 1, 1, 1, NA, NA, NA, NA), `43073` = c(8, 10, NA, NA,
1, 1, 1, 1, NA, NA, 1, NA, 1, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA),
`43076...56` = c(12, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, 1, NA, 1, 1, 1,
1, 1, 1, 1, NA, 1, 1, NA), `43076...57` = c(2, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, 1, NA, 1, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA
), `43085...58` = c(3, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, 1, 1, 1, NA, NA, NA, NA), `43085...59` = c(6, NA,
NA, NA, 1, 1, 1, 1, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA), `43092...60` = c(3, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, 1, NA, 1, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, 1), `43092...61` = c(8,
9, NA, NA, 1, 1, 1, 1, 1, NA, 1, NA, 1, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA), `43093` = c(15, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, 1, NA, 1, 1, 1, 1, 1, NA, 1, 1, 1, 1,
NA, NA, NA, 1, 1, 1, 1), `43099` = c(8, 26, NA, NA, 1, 1,
1, 1, 1, NA, 1, NA, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA)), row.names = c(NA,
-34L), class = c("tbl_df", "tbl", "data.frame")), AC = structure(list(
Date = c("Famsize", "Grpsize", "WAR67", "ABI13", "ABI05",
"AGA93", "AXA17", "AXA13", "ABI82", "ANW15", "ANW10", "WAR79",
"ANA12"), `42880` = c(2, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, 1, 1), `42888` = c(6, 14, NA, 1, NA, 1, NA, 1, 1,
1, 1, NA, NA), `42978...4` = c(3, 5, NA, NA, NA, NA, NA,
NA, 1, 1, 1, NA, NA), `42978...5` = c(3, 7, NA, 1, NA, 1,
NA, 1, NA, NA, NA, NA, NA), `42997` = c(6, 8, NA, 1, NA,
1, NA, 1, 1, 1, 1, NA, NA), `43007` = c(3, 4, NA, NA, NA,
NA, NA, NA, 1, 1, 1, NA, NA), `43025` = c(6, 11, NA, 1, NA,
1, NA, 1, 1, 1, 1, NA, NA), `43069` = c(2, 9, NA, NA, NA,
NA, NA, NA, NA, NA, NA, 1, 1), `43081` = c(3, NA, NA, NA,
NA, 1, 1, 1, NA, NA, NA, NA, NA), `43083` = c(4, NA, NA,
1, NA, 1, 1, 1, NA, NA, NA, NA, NA), `43087` = c(4, 6, NA,
1, NA, NA, NA, NA, 1, 1, 1, NA, NA), `43092` = c(3, 17, NA,
NA, NA, NA, NA, NA, 1, 1, 1, NA, NA), `43096` = c(7, NA,
NA, 1, NA, 1, 1, 1, 1, 1, 1, NA, NA), `43057` = c(4, 8, NA,
1, NA, NA, NA, NA, 1, 1, 1, NA, NA), `43082...16` = c(4,
NA, NA, 1, NA, 1, 1, 1, NA, NA, NA, NA, NA), `43082...17` = c("4",
"6", NA, NA, "?", NA, NA, NA, "1", "1", "1", NA, NA)), row.names = c(NA,
-13L), class = c("tbl_df", "tbl", "data.frame")), BB = structure(list(
Date = c("Famsize", "Grpsize", "BAR", "BAR01", "BDU14", "BAR87",
"BEC16", "BEC11", "BON83", "BRL11", "BON01", "BOL15", "BON93",
"BIL16", "BIL12", "BEV90", "BAA12", "BAA03", "BEV97", "BOD12",
"BRN96", "BLL15", "BLL10", "BEA00", "BEL87", "BOG16", "BOG11",
"BOG04", "Extra12F"), `42943` = c(3, NA, NA, NA, NA, 1, 1,
1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA, NA, NA, NA), `43001` = c(9, 10, 1, 1, 1,
1, 1, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
1, 1, 1, NA, NA, NA, NA, NA, NA), `43008` = c(14, 16, 1,
1, 1, 1, 1, 1, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, 1, 1, 1, 1, 1, 1, 1, 1, 1)), row.names = c(NA, -29L), class = c("tbl_df",
"tbl", "data.frame")), BB2 = structure(list(Date = c("Famsize",
"Grpsize", "BET70", "BNT12", "BNT05", "BNT83", "BRY15", "BRY11"
), `42761` = c(6, 17, 1, 1, 1, 1, 1, 1), `42786` = c(6, 7, 1,
1, 1, 1, 1, 1), `42865` = c(6, NA, 1, 1, 1, 1, 1, 1), `42866` = c(6,
NA, 1, 1, 1, 1, 1, 1), `42871` = c(6, NA, 1, 1, 1, 1, 1, 1),
`42944` = c(6, 10, 1, 1, 1, 1, 1, 1), `43099` = c(6, NA,
1, 1, 1, 1, 1, 1)), row.names = c(NA, -8L), class = c("tbl_df",
"tbl", "data.frame")))
transposed <- as.list(for(family in mysheets$family){
gather(family, na.rm = FALSE)
})
транспонирован, генерирует нулевой результат - ошибка не выдается, но объект пуст
Может кто-нибудь помочьЯ понимаю, как транспонировать каждый кусок в списке, чтобы я мог продолжить с остальной частью проблемы?Спасибо