Uddannelse


Befolkningens uddannelsesstatus


UDXISCPROF_raw <- 
  statgl_url("UDXISCPROF", lang = language) |> 
  statgl_fetch(
    Fsted         = px_all(),
    ISCED11_level = px_all(),
    Aar           = px_top(),
    .col_code     = T
  ) |> 
  as_tibble()

UDXISCPROF <- 
  UDXISCPROF_raw |> 
  select(-Aar) |> 
  mutate(ISCED11_level = ISCED11_level |> fct_inorder()) |> 
  spread(Fsted, value)

UDXISCPROF |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  row_spec(1, bold = T)
I Grønland Udenfor Grønland
I alt 36.779 6.007
Grundskole 10. klasses niveau 21.211 2.904
Gymnasial uddannelse 2.132 302
Erhvervsuddannelse 8.860 910
Suppleringskurser 521 15
Kort videregående uddannelse 1.079 291
Bacheloruddannelse 279 106
Professionsbacheloruddannelse 2.233 640
Kandidatuddannelse 448 795
Phd. og forskeruddannelse 16 44


Se Statistikbankens tabel: UDXISCPROF

UDXUMG3_raw <- 
  statgl_url("UDXUMG3", lang = language) |> 
  statgl_fetch(
    registrering = px_all(),
    HFU          = px_all(),
    aar          = px_top(),
    .col_code    = T
  ) |> 
  as_tibble()

UDXUMG3 <- 
  UDXUMG3_raw |> 
  mutate(HFU = HFU |> fct_inorder() |>  fct_rev()) |>
  select(aar, registrering, HFU, value) |> 
  spread(HFU, value)

UDXUMG3 |> 
  select(-1) |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  row_spec(1, bold = T) |> 
  column_spec(2, bold = T)
I alt Uden afsluttet uddannelse Med afsluttet videregående uddannelse Med afsluttet erhvervsuddannelse Med afsluttet gymnasial uddannelse
Efterskole 266 266 0 0 0
Erhvervsuddannelse 440 360 8 11 61
Gymnasial uddannelse 948 926 0 8 14
I alt 7.323 5.850 112 379 982
I beskæftigelse 3.048 2.211 63 285 489
Ikke i uddannelse eller beskæftigelse 2.235 2.038 8 54 135
Videregående uddannelse 386 49 33 21 283


Se Statistikbankens tabel: UDXUMG3

Grundskolen


UDXESG_raw <- 
  statgl_url("UDXESG", lang = language) |> 
  statgl_fetch(
    unit       = "andel",
    sex        = px_all(),
    efterskole = px_all(),
    status     = px_all(),
    skoleaar   = px_all(),
    .col_code  = T
  ) |> 
  as_tibble()


UDXESG <- 
  UDXESG_raw |> 
  filter(skoleaar == max(skoleaar)) |> 
  mutate(efterskole = efterskole |> fct_inorder() |> fct_rev(),
         sex = sex |> fct_inorder() |> fct_rev()) |> 
  unite(combi, unit, skoleaar, sep = "-")

UDXESG |> 
  select(-combi) |> 
  spread(efterskole, value) |> 
  select(sex, status, 3:6) |> 
  arrange(sex, desc(status)) |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  row_spec(1:3, bold = T) |> 
  column_spec(3, bold = T) |> 
  add_footnote(UDXESG[[1]][1], notation = "symbol")
status I alt Danske efterskoler Maniitsumi Efterskoli Efterskole Villads Villadsen
I alt Påbegyndte i alt 100 100 100 100
I alt Gennemført 66 69 62 57
I alt Afbrudt 34 31 38 43
Piger Påbegyndte i alt 100 100 100 100
Piger Gennemført 66 67 63 63
Piger Afbrudt 34 33 37 38
Drenge Påbegyndte i alt 100 100 100 100
Drenge Gennemført 67 71 61 52
Drenge Afbrudt 33 29 39 48
* andel i procent-2024/2025


Se Statistikbankens tabel: UDXESG

UDXTKK_raw <- 
  statgl_url("UDXTKK", lang = language) |> 
  statgl_fetch(
    subject      = px_all(),
    grade        = px_all(),
    municipality = px_all(),
    unit         = "B",
    time         = px_top(),
    .col_code    = T
  ) |> 
  as_tibble()

UDXTKK <- 
  UDXTKK_raw |> 
  unite(combi, unit, time, sep = " ") |>
  mutate(municipality = municipality |> fct_inorder()) |> 
  spread(subject, value)

UDXTKK |> 
  select(-3) |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  row_spec(c(1, 7), bold = T) |> 
  pack_rows(index = table(UDXTKK[[3]]))
municipality Dansk Engelsk Grønlandsk Matematik
Løsningssikkerhed (pct. rigtige) 2024
  1. klasse
I alt 41 NA 45 49
  1. klasse
Kommune Kujalleq 30 NA 38 43
  1. klasse
Kommuneqarfik Sermersooq 48 NA 43 44
  1. klasse
Qeqqata Kommunia 51 NA 59 63
  1. klasse
Kommune Qeqertalik 36 NA 51 51
  1. klasse
Avannaata Kommunia 41 NA 48 49
  1. klasse
I alt 42 84 56 40
  1. klasse
Kommune Kujalleq 36 53 49 34
  1. klasse
Kommuneqarfik Sermersooq 48 88 48 41
  1. klasse
Qeqqata Kommunia 42 88 64 40
  1. klasse
Kommune Qeqertalik 45 78 66 34
  1. klasse
Avannaata Kommunia 40 84 59 39

Se Statistikbankens tabel: UDXTKK
Ungdoms- og videregående uddannelser


UDXISC11A_raw <- 
  statgl_url("UDXISC11A", lang = language) |> 
  statgl_fetch(
    Isced     = px_all(),
    skoleomr  = px_all(),
    startaar  = px_top(1),
    .col_code = T
  ) |> 
  as_tibble()

UDXISC11A <- 
  UDXISC11A_raw |> 
  mutate(startaar = startaar |> fct_inorder(),
         skoleomr = skoleomr |> fct_inorder()) |> 
  spread(skoleomr, value)

UDXISC11A |> 
  select(-startaar) |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  pack_rows(index = table(UDXISC11A[[2]]))
Skoler i Grønland Skoler i Danmark Skoler i udlandet
2024
Bacheloruddannelse 101 48 2
Erhvervsuddannelse 601 73 0
Gymnasial uddannelse 471 39 2
Kandidatuddannelse 28 21 2
Kort videregående uddannelse 70 26 0
Professionsbacheloruddannelse 135 80 0
Suppleringskurser 123 2 1


Se Statistikbankens tabel: UDXISC11A

UDXISC11L_raw <- 
  statgl_url("UDXISC11L", lang = language) |> 
  statgl_fetch(
    aar       = 2,
    isced     = px_all(),
    status    = px_all(),
    startaar  = px_top(3),
    .col_code = T
  ) |> 
  as_tibble()

UDXISC11L <- 
  UDXISC11L_raw |> 
  filter(value > 0) |> 
  mutate(status = status |> fct_inorder()) |> 
  spread(status, value) |> 
  unite(combi, aar, startaar, sep = " ")

UDXISC11L |> 
  select(-1) |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  add_footnote(UDXISC11L[[1]][1], notation = "symbol")
Aktiv Gennemført Afbrudt Nye påbegyndte i alt
Bacheloruddannelse 57 1 73 131
Erhvervsuddannelse, almen 135 68 265 468
Erhvervsuddannelse, kort 8 135 98 241
Gymnasial uddannelse 200 6 153 359
Kandidatuddannelse 20 12 12 44
Kort videregående uddannelse 8 51 50 109
Professionsbacheloruddannelse 104 13 94 211
* 2 år 2022


Se Statistikbankens tabel: UDXISC11L

Uddannelsesforløb


UDXTRFA1_raw <- 
  statgl_url("UDXTRFA1", lang = language) |> 
  statgl_fetch(
    aar       = 0,
    isced     = px_all(),
    status    = px_all(),
    dim_aar   = px_top(),
    .col_code = T
  ) |> 
  as_tibble()

UDXTRFA1 <- 
  UDXTRFA1_raw |> 
  unite(combi, aar, dim_aar, sep = " ") |> 
  mutate(isced = isced |> fct_inorder(),
         status = status |> fct_inorder())

UDXTRFA1 |> 
  select(-1) |> 
  spread(isced, value) |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  add_footnote(UDXTRFA1[[1]][1], notation = "symbol")
Gymnasial uddannelse Erhvervsuddannelse Ingen registrering
Aktiv 69 6 0
Gennemført 0 0 0
Afbrudt 11 0 0
Ej påbegyndt 0 0 621
* Direkte 2024


Se Statistikbankens tabel: UDXTRFA1


Sidst opdateret: 10. november 2025
---
params:
  lang: "da"
output:
  statgl::statgl_report:
    code_download: true
    code_folding: hide
editor_options: 
  chunk_output_type: console
---

```{r setup, include=FALSE}

knitr::opts_chunk$set(
	echo    = TRUE,
	message = FALSE,
	warning = FALSE,
	class.output = "scroll-100"
)

library("tidyverse")
library("statgl")
library("kableExtra")
library("lubridate")
library("yaml")

language  <- params$lang
option    <- paste0("?lang=", language, "&select")
logo      <- paste0(getwd(),"/add/logo.gif")
txt       <- read_yaml(paste0(getwd(), "/add/txt.yml"), fileEncoding = "ISO-8859-1")
source    <- txt$source[language] %>% unlist()

xaringanExtra::use_clipboard()

```

```{css, echo = FALSE}

.accordion {
  background-color: #919900;
  color: white;
  cursor: pointer;
  padding: 18px;
  width: 100%;
  border: none;
  border-radius: 5px;
  text-align: left;
  outline: none;
  font-size: 15px;
  transition: 0.4s;
}

.active, .accordion:hover {
  background-color: #f97242;
}

.accordion:after {
  content: '\002B';
  color: #777;
  font-weight: bold;
  float: right;
  margin-left: 5px;
}

.active:after {
  content: "\2212";
}

.panel {
  padding: 0px 5px 0px 5px;
  background-color: white;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.2s ease-out;
}

details {
  width: 100%;
}

details > summary {
  padding: 4px 12px;
  width: 100%;
  background-color: #007f99;
  border: solid;
  border-color: white;
  border-radius: 5px;
  cursor: pointer;
  font-size: 15px;
  color: white;
}

details[open] > summary {
  background-color: #faa41a;
}


.title {
  color: #1b5463;
  font-size: 36px;
}


.personer {
  box-shadow: 3px 3px 4px black;
  background: #004459;
  padding-right: 15px;
  padding-left: 16px;
  padding-top: 0.1px;
  padding-bottom: 1px;
  font-size: 11px;
  color: white;
  vertical-align: middle;
}

.økonomi {
  box-shadow: 3px 3px 4px black;
  background: #007F99;
  padding-right: 15px;
  padding-left: 16px;
  padding-top: 1px;
  padding-bottom: 0.1px;
  font-size: 11px;
  color: white;
  vertical-align: middle;
}

.tværgående {
  box-shadow: 3px 3px 4px black;
  background: #faa41a;
  padding-right: 15px;
  padding-left: 16px;
  padding-top: 0.1px;
  padding-bottom: 1px;
  font-size: 11px;
  color: white;
  vertical-align: middle;
}

.container {
  width: inherit;
}

.scroll-100 {
  max-height: 100;
  overflow-y: auto;
  background-color: inherit;
}


pre {
  max-height: 300px;
  overflow-y: auto;
}

pre[class] {
  max-height: 300px;
}

```

<br>
<br>

<center>

---
 
# [`r txt$UD$title[language]`]{.title}
 
---
</center>

<details> <summary> `r txt$UD$sub1[language]` </summary> 
<br>

<button class="accordion"> `r paste0("**Tabel 1: **", statgl_meta(statgl_url("UDXISCPROF", lang = language))[1]$title) ` </button> <div class="panel">

```{r UDXISCPROF}

UDXISCPROF_raw <- 
  statgl_url("UDXISCPROF", lang = language) |> 
  statgl_fetch(
    Fsted         = px_all(),
    ISCED11_level = px_all(),
    Aar           = px_top(),
    .col_code     = T
  ) |> 
  as_tibble()

UDXISCPROF <- 
  UDXISCPROF_raw |> 
  select(-Aar) |> 
  mutate(ISCED11_level = ISCED11_level |> fct_inorder()) |> 
  spread(Fsted, value)

UDXISCPROF |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  row_spec(1, bold = T)

```
<br>
[![](`r logo`){width=40}`r paste(source, "UDXISCPROF")`](`r paste0("https://bank.stat.gl:443/sq/176eaa41-0b00-4cc4-b8a3-082f95c49e02", option)`){target="_blank"}
</div>

<button class="accordion"> `r paste0("**Tabel 2: **", statgl_meta(statgl_url("UDXUMG3", lang = language))[1]$title) ` </button> <div class="panel">

```{r UDXUMG3}

UDXUMG3_raw <- 
  statgl_url("UDXUMG3", lang = language) |> 
  statgl_fetch(
    registrering = px_all(),
    HFU          = px_all(),
    aar          = px_top(),
    .col_code    = T
  ) |> 
  as_tibble()

UDXUMG3 <- 
  UDXUMG3_raw |> 
  mutate(HFU = HFU |> fct_inorder() |>  fct_rev()) |>
  select(aar, registrering, HFU, value) |> 
  spread(HFU, value)

UDXUMG3 |> 
  select(-1) |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  row_spec(1, bold = T) |> 
  column_spec(2, bold = T)

```
<br>
[![](`r logo`){width=40}`r paste(source, "UDXUMG3")`](`r paste0("https://bank.stat.gl:443/sq/15020386-d823-4e31-bfb4-150eb91d085a", option)`){target="_blank"}
</div>

</details>

<details> <summary> `r txt$UD$sub2[language]` </summary> 
<br>

<button class="accordion"> `r paste0("**Tabel 3: **", statgl_meta(statgl_url("UDXESG", lang = language))[1]$title) ` </button> <div class="panel">

```{r UDXESG}

UDXESG_raw <- 
  statgl_url("UDXESG", lang = language) |> 
  statgl_fetch(
    unit       = "andel",
    sex        = px_all(),
    efterskole = px_all(),
    status     = px_all(),
    skoleaar   = px_all(),
    .col_code  = T
  ) |> 
  as_tibble()


UDXESG <- 
  UDXESG_raw |> 
  filter(skoleaar == max(skoleaar)) |> 
  mutate(efterskole = efterskole |> fct_inorder() |> fct_rev(),
         sex = sex |> fct_inorder() |> fct_rev()) |> 
  unite(combi, unit, skoleaar, sep = "-")

UDXESG |> 
  select(-combi) |> 
  spread(efterskole, value) |> 
  select(sex, status, 3:6) |> 
  arrange(sex, desc(status)) |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  row_spec(1:3, bold = T) |> 
  column_spec(3, bold = T) |> 
  add_footnote(UDXESG[[1]][1], notation = "symbol")

```
<br>
[![](`r logo`){width=40}`r paste(source, "UDXESG")`](`r paste0("https://bank.stat.gl:443/sq/63fa1f20-7932-4c7a-86e3-bf6ff59db7d3", option)`){target="_blank"}
</div>


<button class="accordion"> `r paste0("**Tabel 4: **", statgl_meta(statgl_url("UDXTKK", lang = language))[1]$title) ` </button> <div class="panel">
```{r UDXTKK}

UDXTKK_raw <- 
  statgl_url("UDXTKK", lang = language) |> 
  statgl_fetch(
    subject      = px_all(),
    grade        = px_all(),
    municipality = px_all(),
    unit         = "B",
    time         = px_top(),
    .col_code    = T
  ) |> 
  as_tibble()

UDXTKK <- 
  UDXTKK_raw |> 
  unite(combi, unit, time, sep = " ") |>
  mutate(municipality = municipality |> fct_inorder()) |> 
  spread(subject, value)

UDXTKK |> 
  select(-3) |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  row_spec(c(1, 7), bold = T) |> 
  pack_rows(index = table(UDXTKK[[3]]))




```
<br>
[![](`r logo`){width=40}`r paste(source, "UDXTKK")`](`r paste0("https://bank.stat.gl:443/sq/0b3ce5d3-7e97-443f-981f-f7d123fcfb40", option)`){target="_blank"}
</div>


</details>


<details> <summary> `r txt$UD$sub3[language]` </summary> 
<br>

<button class="accordion"> `r paste0("**Tabel 5: **", statgl_meta(statgl_url("UDXISC11A", lang = language))[1]$title) ` </button> <div class="panel">
```{r UDXISC11A}

UDXISC11A_raw <- 
  statgl_url("UDXISC11A", lang = language) |> 
  statgl_fetch(
    Isced     = px_all(),
    skoleomr  = px_all(),
    startaar  = px_top(1),
    .col_code = T
  ) |> 
  as_tibble()

UDXISC11A <- 
  UDXISC11A_raw |> 
  mutate(startaar = startaar |> fct_inorder(),
         skoleomr = skoleomr |> fct_inorder()) |> 
  spread(skoleomr, value)

UDXISC11A |> 
  select(-startaar) |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  pack_rows(index = table(UDXISC11A[[2]]))


```
<br>
[![](`r logo`){width=40}`r paste(source, "UDXISC11A")`](`r paste0("https://bank.stat.gl:443/sq/17e69526-8885-4a45-936e-33c60dcba8b4", option)`){target="_blank"}
</div>


<button class="accordion"> `r paste0("**Tabel 6: **", statgl_meta(statgl_url("UDXISC11L", lang = language))[1]$title) ` </button> <div class="panel">
```{r UDXISC11L}

UDXISC11L_raw <- 
  statgl_url("UDXISC11L", lang = language) |> 
  statgl_fetch(
    aar       = 2,
    isced     = px_all(),
    status    = px_all(),
    startaar  = px_top(3),
    .col_code = T
  ) |> 
  as_tibble()

UDXISC11L <- 
  UDXISC11L_raw |> 
  filter(value > 0) |> 
  mutate(status = status |> fct_inorder()) |> 
  spread(status, value) |> 
  unite(combi, aar, startaar, sep = " ")

UDXISC11L |> 
  select(-1) |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  add_footnote(UDXISC11L[[1]][1], notation = "symbol")



```
<br>
[![](`r logo`){width=40}`r paste(source, "UDXISC11L")`](`r paste0("https://bank.stat.gl:443/sq/e4b076e8-f702-46d8-bfec-bedd5621c5da", option)`){target="_blank"}
</div>

</details>



<details> <summary> `r txt$UD$sub4[language]` </summary> 
<br>

<button class="accordion"> `r paste0("**Tabel 7: **", statgl_meta(statgl_url("UDXTRFA1", lang = language))[1]$title) ` </button> <div class="panel">
```{r UDXTRFA1}

UDXTRFA1_raw <- 
  statgl_url("UDXTRFA1", lang = language) |> 
  statgl_fetch(
    aar       = 0,
    isced     = px_all(),
    status    = px_all(),
    dim_aar   = px_top(),
    .col_code = T
  ) |> 
  as_tibble()

UDXTRFA1 <- 
  UDXTRFA1_raw |> 
  unite(combi, aar, dim_aar, sep = " ") |> 
  mutate(isced = isced |> fct_inorder(),
         status = status |> fct_inorder())

UDXTRFA1 |> 
  select(-1) |> 
  spread(isced, value) |> 
  rename(" " = 1) |> 
  statgl_table() |> 
  add_footnote(UDXTRFA1[[1]][1], notation = "symbol")



```
<br>
[![](`r logo`){width=40}`r paste(source, "UDXTRFA1")`](`r paste0("https://bank.stat.gl:443/sq/7ea156dd-59b1-41e6-9a11-94ffc91538d2", option)`){target="_blank"}
</div>

</details>




<hr style="border:1px ridge lightgray"> </hr>
<center> <span style='color:#D3D3D3; font-size:90%;'> `r paste(txt$update[language], format(Sys.Date(), "%d. %B %Y"))` </span> </center>




<script>
var acc = document.getElementsByClassName("accordion");
var i;

for (i = 0; i < acc.length; i++) {
  acc[i].addEventListener("click", function() {
    this.classList.toggle("active");
    var panel = this.nextElementSibling;
    if (panel.style.maxHeight) {
      panel.style.maxHeight = null;
    } else {
      panel.style.maxHeight = panel.scrollHeight + "px";
    } 
  });
}
</script>






