Sort by

recency

|

390 Discussions

|

  • + 0 comments
    import sys, re
    
    text = sys.stdin.read().splitlines()[1:]
    HEX_pattern = r"[#][0-9a-f]{3,6}"
    
    index_list = []
    line_list = []
    match = ''
    
    i = 0 
    for line in text:
        if not re.search(r"^(#|{|})", line): 
                index_list.append(i)
        i+=1
    
    for index in index_list:
        line_list.append(text[index])
    
    match ='\n'.join(re.findall(HEX_pattern, ''.join(line_list), flags=re.I))
    print(match)
    
  • + 0 comments
    import re
    pattern = r'#[0-9A-Fa-f]{6}\b|#[0-9A-Fa-f]{3}\b'
    n = int(input().strip())
    inside = False
    for _ in range(n):
        t = input()
        if "{" in t: 
            inside = True
        elif "}" in t: 
            inside = False
        elif inside:
            [print(x) for x  in re.findall(pattern,  t)]
    
  • + 0 comments

    My solution, matching only within {} sections

    import re
    
    n = int(input())
    
    css=""
    for i in range(n):
        css += input()
    
    rsection = r"{.*?}"
    rhexcode = r"#[0-9A-Fa-f]{6}|#[0-9A-Fa-f]{3}"
    
    sections = re.findall(rsection,css)
        
    for s in sections:
        hexcodes = re.findall(rhexcode,s)
        for hc in hexcodes:
            print(hc)
    
  • + 0 comments
    import re
    
    pattern = r'#[0-9ABCDEFabcdef]{3,6}[();,?]'
    
    N = int(input())
    
    for i in range(N):
        txt = input()
        li = re.findall(pattern, txt)
        if len(li) > 0:
            for a in li:
                print(a[:-1])
    
  • + 0 comments
    import re
    
    for i in range(int(input())):
        s = input()
        matches = re.findall(r"[.:\s](#[0-9A-Fa-f]{6}|#[0-9A-Fa-f]{3})", s)
        if matches:
            print(*matches, sep="\n")