Erhverv


Erhvervsstruktur
ESX1A_raw <- 
  statgl_url("ESX1A", lang = language) %>% 
  statgl_fetch(
    section    = px_all(),
    variable   = px_all(),
    aar        = px_top(),
    .col_code  = TRUE
  ) %>% 
  as_tibble()

ESX1A <- 
  ESX1A_raw %>% 
  mutate(
    variable = variable %>% fct_inorder(),
    section = section %>% str_remove_all(".\\.") %>% trimws(),
    section = section %>% fct_reorder(value, .fun = sum, .desc = TRUE),
    ) %>% 
  spread(variable, value)

ESX1A %>% 
  select(-aar) %>% 
  rename(" " = 1) %>% 
  statgl_table() %>% 
  pack_rows(index = ESX1A[["aar"]] %>% table()) %>% 
  row_spec(1, bold = TRUE)
Antal virksomheder Gennemsnitlig lønsum i mio. kr. Lønsum i mio. kr.
2022
Total 3.914 2,01 7.853,3
Fiskeri og fiskerirelateret industri og handel 1.999 1,05 2.102,2
Bygge- og anlægsvirksomhed 246 5,59 1.376,0
Transport og godshåndtering 203 5,21 1.057,9
Engroshandel og detailhandel: reparation af motorkøretøjer og motorcykler 218 4,13 900,2
Administrative tjenesteydelser og hjælpetjenester 160 2,53 405,0
Liberale, videnskabelige og tekniske tjenesteydelser 204 1,44 293,4
Overnatningsfaciliteter og restaurationsvirksomhed 117 2,70 315,5
Information og kommunikation 89 3,31 294,3
Uoplyst 132 1,55 204,9
Sundhedsvæsen og sociale foranstaltninger 91 1,87 169,8
Andre serviceydelser 121 0,69 84,0
Pengeinstitut- og finansvirksomhed, forsikring 19 9,27 176,1
Fast ejendom 68 1,95 132,3
Fremstillingsvirksomhed 73 1,65 120,3
Råstofindvinding 28 3,43 95,9
Kultur, forlystelser og sport 64 0,89 57,1
Undervisning 43 1,24 53,4
Vandforsyning: kloakvæsen og affaldhåndtering 39 0,39 15,0


Se Statistikbankens tabel: ESX1A

Regnskabsstatistik


ESXINVST_raw <- 
  statgl_url("ESXINVST", lang = language) %>%
  statgl_fetch(
    industry  = px_all(),
    items     = px_top(3),
    time      = px_top(1),
    .col_code = TRUE
  ) %>% 
  as_tibble()

ESXINVST <- 
  ESXINVST_raw %>% 
  mutate(
    items = items %>% fct_inorder(),
    industry = industry %>% str_remove_all(".\\.") %>% trimws(),
    industry = industry %>% fct_reorder(value, .fun = sum, .desc = T)
  ) %>% 
  spread(items, value)

ESXINVST %>% 
  select(-time) %>% 
  rename(" " = 1) %>% 
  statgl_table() %>% 
  pack_rows(index = ESXINVST[["time"]] %>% table())
Investeringer, netto Tilgang i alt Afgang i alt
2022
Alle brancher 3.256.708 5.126.131 -1.869.423
Alle brancher eksk råstofindvinding 3.176.509 5.012.486 -1.835.977
Transport og godshåndtering 1.482.215 2.132.170 -649.955
Fast ejendom 1.047.058 1.241.549 -194.491
Fiskeri og fiskerirelateret industri og handel 352.112 474.412 -122.300
Information og kommunikation 139.897 192.225 -52.328
Liberale, videnskabelige og tekniske tjenesteydelser 134.340 160.048 -25.708
Bygge- og anlægsvirksomhed 121.688 262.500 -140.812
Engroshandel og detailhandel: reparation af motorkøretøjer og motorcykler 101.185 403.382 -302.197
Råstofindvinding 80.199 113.645 -33.446
Overnatningsfaciliteter og restaurationsvirksomhed 14.570 46.182 -31.612
Fremstillingsvirksomhed 13.942 22.217 -8.275
Pengeinstitut- og finansvirksomhed, forsikring -13.277 14.876 -28.153
Administrative tjenesteydelser og hjælpetjenester -217.221 62.925 -280.146


Se Statistikbankens tabel: ESXINVST

ESXNGL_raw <- 
  statgl_url("ESXNGL", lang = language) %>%
  statgl_fetch(
    industry  = px_top(1),
    items     = px_all(),
    time      = px_top(1),
    .col_code = TRUE
  ) %>% 
  as_tibble()

ESXNGL <- 
  ESXNGL_raw %>% 
  mutate(value = value |> prettyNum(big.mark = ".", decimal.mark = ",")) |> 
  spread(industry, value) 
  

ESXNGL %>% 
  select(-time) %>% 
  rename(" " = 1) %>% 
  statgl_table() %>% 
  pack_rows(index = ESXNGL[["time"]] %>% table())
Alle brancher
2022
Afkastningsgrad 3,4
Aktivernes omsætningshastighed (grad) 0,5
Antal virksomheder 973
Egenkapitalens forretning 3,8
Likviditetsgrad (Ratio) 1,1
Overskudsgrad 6,4
Soliditetsgrad 37,9
Værditilvækst (1.000 kr.) 9.407.953


Se Statistikbankens tabel: ESXNGL


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$ES$title[language]`]{.title}
 
---
</center>

<details> <summary> `r txt$ES$sub1[language]` </summary> 
<br>
<button class="accordion"> `r paste0("**Tabel 1: **", statgl_meta(statgl_url("ESX1A", lang = language))[1]$title) ` </button> <div class="panel">
```{r ESX1A}

ESX1A_raw <- 
  statgl_url("ESX1A", lang = language) %>% 
  statgl_fetch(
    section    = px_all(),
    variable   = px_all(),
    aar        = px_top(),
    .col_code  = TRUE
  ) %>% 
  as_tibble()

ESX1A <- 
  ESX1A_raw %>% 
  mutate(
    variable = variable %>% fct_inorder(),
    section = section %>% str_remove_all(".\\.") %>% trimws(),
    section = section %>% fct_reorder(value, .fun = sum, .desc = TRUE),
    ) %>% 
  spread(variable, value)

ESX1A %>% 
  select(-aar) %>% 
  rename(" " = 1) %>% 
  statgl_table() %>% 
  pack_rows(index = ESX1A[["aar"]] %>% table()) %>% 
  row_spec(1, bold = TRUE)

```
<br>
[![](`r logo`){width=40}`r paste(source, "ESX1A")`](`r paste0("https://bank.stat.gl:443/sq/a599d85b-ab43-428a-a91a-03bd95a80232", option)`){target="_blank"}
</div> 

</details>

<details> <summary> `r txt$ES$sub2[language]` </summary>
<br>


<button class="accordion"> `r paste0("**Tabel 2: **", statgl_meta(statgl_url("ESXINVST", lang = language))[1]$title) ` </button> <div class="panel">

```{r ESXINVST}

ESXINVST_raw <- 
  statgl_url("ESXINVST", lang = language) %>%
  statgl_fetch(
    industry  = px_all(),
    items     = px_top(3),
    time      = px_top(1),
    .col_code = TRUE
  ) %>% 
  as_tibble()

ESXINVST <- 
  ESXINVST_raw %>% 
  mutate(
    items = items %>% fct_inorder(),
    industry = industry %>% str_remove_all(".\\.") %>% trimws(),
    industry = industry %>% fct_reorder(value, .fun = sum, .desc = T)
  ) %>% 
  spread(items, value)

ESXINVST %>% 
  select(-time) %>% 
  rename(" " = 1) %>% 
  statgl_table() %>% 
  pack_rows(index = ESXINVST[["time"]] %>% table())

```
<br>
[![](`r logo`){width=40}`r paste(source, "ESXINVST")`](`r paste0("https://bank.stat.gl:443/sq/808dd812-62a8-4fc3-a4c5-5f7325c7a2fc", option)`){target="_blank"}
</div> 


<button class="accordion"> `r paste0("**Tabel 3: **", statgl_meta(statgl_url("ESXNGL", lang = language))[1]$title) ` </button> <div class="panel">

```{r ESXNGL}


ESXNGL_raw <- 
  statgl_url("ESXNGL", lang = language) %>%
  statgl_fetch(
    industry  = px_top(1),
    items     = px_all(),
    time      = px_top(1),
    .col_code = TRUE
  ) %>% 
  as_tibble()

ESXNGL <- 
  ESXNGL_raw %>% 
  mutate(value = value |> prettyNum(big.mark = ".", decimal.mark = ",")) |> 
  spread(industry, value) 
  

ESXNGL %>% 
  select(-time) %>% 
  rename(" " = 1) %>% 
  statgl_table() %>% 
  pack_rows(index = ESXNGL[["time"]] %>% table())

```
<br>
[![](`r logo`){width=40}`r paste(source, "ESXNGL")`](`r paste0("https://bank.stat.gl:443/sq/ee8b2a75-82b9-4961-9614-aa1dcbb4dc33", 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>


