Last active
          June 14, 2025 23:11 
        
      - 
      
- 
        Save jimjam-slam/e78c5c7b94e8cc66e4fe16b217a5922c to your computer and use it in GitHub Desktop. 
    Convert ISO 3166-1 alpha-2 country codes to their corresponding emoji flag control sequences (either as Unicode characters or ASCII strings). Great for use with the countrycode, emojifont and emoGG packages! Requires stringr (part of the tidyverse).
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | # these two functions, iso_to_emoji_unicode and iso_to_emoji_ascii, convert two-letter iso country codes | |
| # (eg. australia = AU) to the unicode control sequences used for their flag emoji. the _unicode function | |
| # outputs the actual unicode characters (printed in R in ascii but stored in ascii); the _ascii function | |
| # outputs an ascii representation (with the argument ligature_sep in between the two strings). | |
| library(stringr) | |
| # iso_to_emoji_unicode: for a vector of two-letter iso codes, returns a | |
| # corresponding vector of two-character unicode control sequences. | |
| # (nb: R prints them in ascii, but they're really stored as unicode characters) | |
| # great for use with countrycode and emojifont! | |
| iso_to_emoji_unicode = function(iso_codes) | |
| { | |
| # check input | |
| if (!any( | |
| nchar(iso_codes) == 2 | | |
| is.na(iso_codes))) | |
| { | |
| stop('iso_to_emoji: ISO codes must be two (2) letters long.') | |
| } | |
| if (!any( | |
| str_detect(iso_codes, pattern = '[a-zA-Z][a-zA-Z]') | | |
| is.na(iso_codes))) | |
| { | |
| stop('iso_to_emoji: ISO codes must be letters only.') | |
| } | |
| # substitute unicode regional indicator symbols for the original characters | |
| return(str_replace_all(str_to_lower(iso_codes), c('a' = '๐ฆ', 'b' = '๐ง', 'c' = '๐จ', | |
| 'd' = '๐ฉ', 'e' = '๐ช', 'f' = '๐ซ', 'g' = '๐ฌ', 'h' = '๐ญ', 'i' = '๐ฎ', | |
| 'j' = '๐ฏ', 'k' = '๐ฐ', 'l' = '๐ฑ', 'm' = '๐ฒ', 'n' = '๐ณ', 'o' = '๐ด', | |
| 'p' = '๐ต', 'q' = '๐ถ', 'r' = '๐ท', 's' = '๐ธ', 't' = '๐น', 'u' = '๐บ', | |
| 'v' = '๐ป', 'w' = '๐ผ', 'x' = '๐ฝ', 'y' = '๐พ', 'z' = '๐ฟ'))) | |
| } | |
| # iso_to_emoji_ascii: for a vector of two-letter iso codes, returns | |
| # a corresponding vector of ascii-formatted unicode control sequences. | |
| # great for downloading files named with unicode control points! | |
| iso_to_emoji_ascii = function(iso_codes, ligature_sep = '-') | |
| { | |
| # check input | |
| if (!any( | |
| nchar(iso_codes) == 2 | | |
| is.na(iso_codes))) | |
| { | |
| stop('iso_to_emoji: ISO codes must be two (2) letters long.') | |
| } | |
| if (!any( | |
| str_detect(iso_codes, pattern = '[a-zA-Z][a-zA-Z]') | | |
| is.na(iso_codes))) | |
| { | |
| stop('iso_to_emoji: ISO codes must be letters only.') | |
| } | |
| # add each letter's position in the alphabet to the start of the | |
| # regional indicator symbol block; format as string | |
| iso_codes %<>% str_to_lower | |
| return( | |
| paste0( | |
| as.hexmode(0x1f1e5 + match(substr(iso_codes, 1, 1), letters)), | |
| ligature_sep, | |
| as.hexmode(0x1f1e5 + match(substr(iso_codes, 2, 2), letters)))) | |
| } | 
This works for me:
export function isoToEmoji(iso: string): string { const codePoints = iso .toUpperCase() .split('') .map((char) => 127397 + char.charCodeAt(0)); return String.fromCodePoint(...codePoints); }
It's super simple and actually really useful.
@shiny @viktorvillalobos This is a neat solution, but the gist is in R, not JavaScript.
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
            
This works for me: