o
    ,hŉ                     @   s  U d dl Z d dlZd dlmZmZmZmZ d dlmZ i Z	ee
ef ed< i ddddd	d
dddddddddddddddddddddddddd
ddi ddddddd dd!dd"dd#dd$dd%dd&dd'dd(dd)dd*dd+dd,d-d.d/i d0d1d2d1d3d/d4dd5dd6d/d7d/d8dd9dd:d1d;d
d<d=d>dd?dd@d1dAddBd1i dCddDddEd/dFd/dGd-dHd1dIddJddKddLd
dMddNddOddPddQddRd1dSd
i dTd1dUd1dVddWddXd1dYddZdd[dd\dd]d=d^d1d_d1d`d1dad1dbddcd
dddd1ddddd
ddddde
ZdfZedgZedhZediZedje dMZedke dMZedlZedmZednZ	o	oddpe
dqe
dredsedtef
dudvZdpe
dqe
dtefdwdxZddqe
dsedtefdydzZd{edtee
e
f fd|d}Zd{edtee
e
eef fd~dZde
de
de
de
dtef
ddZde
de
de
de
dtef
ddZdede
de
de
de
dtefddZ dedtefddZ!dedte
fddZ"dedte
fddZ#dedtefddZ$dedtefddZ%de
dteeeeef f fddZ&dee j e j'e j(f dtefddZ)de j dedte j fddZ*dee j'e j e j+e j(f dededte,fddZ-dedteej. fddZ/dS )    N)DictOptionalTupleUnion)warn	COL_NAMES    !   "   #   $%   &
   '()*+,   -./0123456789:;<=>?@   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[\]^_`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{|}~uC  ©®‼⁉™ℹ↔-↙↩↪⌚⌛⌨⏏⏩-⏳⏸-⏺Ⓜ▪▫▶◀◻-◾☀-☄☎☑☔☕☘☝☠☢☣☦☪☮☯☸-☺♀♂♈-♓♟♠♣♥♦♨♻♾♿⚒-⚗⚙⚛⚜⚠⚡⚧⚪⚫⚰⚱⚽⚾⛄⛅⛈⛎⛏⛑⛓⛔⛩⛪⛰-⛵⛷-⛺⛽✂✅✈-✍✏✒✔✖✝✡✨✳✴❄❇❌❎❓-❕❗❣❤➕-➗➡➰➿⤴⤵⬅-⬇⬛⬜⭐⭕〰〽㊗㊙🀄🃏🅰🅱🅾🅿🆎🆑-🆚🇦-🇿🈁🈂🈚🈯🈲-🈺🉐🉑🌀-🌡🌤-🎓🎖🎗🎙-🎛🎞-🏰🏳-🏵🏷-📽📿-🔽🕉-🕎🕐-🕧🕯🕰🕳-🕺🖇🖊-🖍🖐🖕🖖🖤🖥🖨🖱🖲🖼🗂-🗄🗑-🗓🗜-🗞🗡🗣🗨🗯🗳🗺-🙏🚀-🛅🛋-🛒🛕-🛗🛜-🛥🛩🛫🛬🛰🛳-🛼🟠-🟫🟰🤌-🤺🤼-🥅🥇-🧿🩰-🩼🪀-🪈🪐-🪽🪿-🫅🫎-🫛🫠-🫨🫰-🫸z^\sz\s$z(\$?)([A-Z]{1,3})(\$?)(\d+)z[^\w\.z^[\d\.z^([A-Z]{1,3}\d+)$z^R(\d+)z	^R?C(\d+)Frowcolrow_abscol_absreturnc                 C   sf   | dk rt d|  d dS |dk rt d| d dS | d7 } |r$dnd}t||}|| t|  S )aU  
    Convert a zero indexed row and column cell reference to a A1 style string.

    Args:
       row:     The cell row.    Int.
       col:     The cell column. Int.
       row_abs: Optional flag to make the row absolute.    Bool.
       col_abs: Optional flag to make the column absolute. Bool.

    Returns:
        A1 style string.

    r   zRow number '' must be >= 0 Col number '   r   )r   xl_col_to_namestr)rr   rs   rt   ru   row_abs_strcol_str r   H/var/www/html/rh/venv/lib/python3.10/site-packages/xlsxwriter/utility.pyxl_rowcol_to_cell   s   
r   c                 C   s2   |t v r	t | }nt|}|t |< |t| d  S )z
    Optimized version of the xl_rowcol_to_cell function. Only used internally.

    Args:
       row: The cell row.    Int.
       col: The cell column. Int.

    Returns:
        A1 style string.

    rz   )r   r{   r|   )rr   rs   r~   r   r   r   xl_rowcol_to_cell_fast   s
   
r   c                 C   s   | }|dk rt d| d dS |d7 }d}|rdnd}|r@|d }|dkr(d}ttd| d }|| }t|d d }|s|| S )	z
    Convert a zero indexed column cell reference to a string.

    Args:
       col:     The cell column. Int.
       col_abs: Optional flag to make the column absolute. Bool.

    Returns:
        Column style string.

    r   ry   rw   rx   rz   r      r1   )r   chrordint)rs   ru   col_numr~   col_abs_str	remainder
col_letterr   r   r   r{      s    r{   cell_strc                 C   s   | sdS t | }|du rtd|  d dS |d}|d}d}d}t|D ]}|t|td d	 d
|  7 }|d	7 }q)t|d	 }|d	8 }||fS )z
    Convert a cell reference in A1 notation to a zero indexed row and column.

    Args:
       cell_str:  A1 style string.

    Returns:
        row, col: Zero indexed cell row and column indices.

    )r   r   NInvalid cell reference 'r      r   r   r1   rz   r   )RE_RANGE_PARTSmatchr   groupreversedr   r   )r   r   r~   row_strexpnrs   charrr   r   r   r   xl_cell_to_rowcol   s    


 
r   c           
      C   s   | sdS t | }|du rtd|  d dS t|d}|d}t|d}|d}d	}d	}t|D ]}|t|td
 d d|  7 }|d7 }q7t|d }	|d8 }|	|||fS )a!  
    Convert an absolute cell reference in A1 notation to a zero indexed
    row and column, with True/False values for absolute rows or columns.

    Args:
       cell_str: A1 style string.

    Returns:
        row, col, row_abs, col_abs:  Zero indexed cell row and column indices.

    )r   r   FFNr   r   rz   r   r	   r   r   r1   r   )r   r   r   boolr   r   r   r   )
r   r   ru   r~   rt   r   r   rs   r   rr   r   r   r   xl_cell_to_rowcol_abs  s$   


 
r   	first_row	first_collast_rowlast_colc                 C   sH   t | |}t ||}|dks|dkrtd dS ||kr|S |d | S )aG  
    Convert zero indexed row and col cell references to a A1:B1 range string.

    Args:
       first_row: The first cell row.    Int.
       first_col: The first cell column. Int.
       last_row:  The last cell row.     Int.
       last_col:  The last cell column.  Int.

    Returns:
        A1:B1 style range string.

    rx   #Row and column numbers must be >= 0r)   r   r   r   r   r   r   range1range2r   r   r   xl_range3  s   

r   c                 C   sP   t | |dd}t ||dd}|dks|dkrtd dS ||kr"|S |d | S )a\  
    Convert zero indexed row and col cell references to a $A$1:$B$1 absolute
    range string.

    Args:
       first_row: The first cell row.    Int.
       first_col: The first cell column. Int.
       last_row:  The last cell row.     Int.
       last_col:  The last cell column.  Int.

    Returns:
        $A$1:$B$1 style range string.

    Trx   r   r)   r   r   r   r   r   xl_range_absN  s   r   	sheetnamec                 C   s"   t ||||}t| } | d | S )a  
    Convert worksheet name and zero indexed row and col cell references to
    a Sheet1!A1:B1 range formula string.

    Args:
       sheetname: The worksheet name.    String.
       first_row: The first cell row.    Int.
       first_col: The first cell column. Int.
       last_row:  The last cell row.     Int.
       last_col:  The last cell column.  Int.

    Returns:
        A1:B1 style range string.

    r
   )r   quote_sheetname)r   r   r   r   r   
cell_ranger   r   r   xl_range_formulaj  s   r   c                 C   s8  |   }d}d}d}| dst|}t|}t|}t| r&d}nft| r.d}n^|rV|	d}t
|\}	}
d|	  krE|k rUn nEd|
  krQ|k rUn n9d}n6|rnt|	d}	d|	  k ri|krmn n!d}n|rt|	d}
d|
  k r|krn n	d}n|dv rd}|r| dd	} d|  d} | S )
a,  
    Sheetnames used in references should be quoted if they contain any spaces,
    special characters or if they look like a A1 or RC cell reference. The rules
    are shown inline below.

    Args:
       sheetname: The worksheet name. String.

    Returns:
        A quoted worksheet string.

    Fi @  i   r   Trz   r   )rE   r5   RCz'')upper
startswithRE_QUOTE_RULE3r   RE_QUOTE_RULE4_ROWRE_QUOTE_RULE4_COLUMNRE_QUOTE_RULE1searchRE_QUOTE_RULE2r   r   r   replace)r   uppercase_sheetnamerequires_quotingcol_maxrow_maxmatch_rule3match_rule4_rowmatch_rule4_columncellrr   rs   r   r   r   r     sD   






0r   stringc                 C   s    | rt | dkr
dS t| d S )z
    Calculate the width required to auto-fit a string in a cell.

    Args:
       string: The string to calculate the cell width for. String.

    Returns:
        The string autofit width in pixels. Returns 0 if the string is empty.

    r   r   )lenxl_pixel_widthr   r   r   r   cell_autofit_width  s   r   c                 C   s"   d}| D ]
}|t |d7 }q|S )a}  
    Get the pixel width of a string based on individual character widths taken
    from Excel. UTF8 characters, and other unhandled characters, are given a
    default width of 8.

    Args:
       string: The string to calculate the width for. String.

    Returns:
        The string width in pixels. Note, Excel adds an additional 7 pixels of
        padding in the cell.

    r   r4   )CHAR_WIDTHSget)r   lengthr   r   r   r   r     s   r   colorc                 C   s   i ddddddddd	d
dddddddddddddddddddddd}| | | } td | sFtd!|  d" d#| d$  S )%Nblackz#000000bluez#0000FFbrownz#800000cyanz#00FFFFgrayz#808080greenz#008000limez#00FF00magentaz#FF00FFnavyz#000080orangez#FF6600pinkpurplez#800080redz#FF0000silverz#C0C0C0whitez#FFFFFFyellowz#FFFF00z#[0-9a-fA-F]{6}zColor 'z' isn't a valid Excel colorFFr   )r   rer   r   lstripr   )r   named_colorsr   r   r   	_xl_color  sJ   	
r   c                 C   s   t | }tdd|}|S )Nz^FFrx   )r   r   sub)r   	rgb_colorr   r   r   _get_rgb_color"  s   r   style_idc              
   C   s(  g dddddidddddddddddiddiddddddidddddddddddiddiddddddidddddddddddiddidddddd	idddddddddddiddidd	dddd
id	ddd	ddd	dddd	idd	idd
ddddid
ddd
ddd
dddd
idd
iddddddidddddddddddiddiddddddidddddddddddddddddddddiddddddddddddddddddddd	id	ddd	ddd	ddd	ddd	dddd	dddd
id
ddd
ddd
ddd
ddd
dddd
ddddidddddddddddddddddddddiddddddddddddddddddiddiddddddddddddddddddiddiddddddddddddddddddidd	idddddddddddddddddd	idd
id	ddd	ddd	ddd	ddd	ddddd
iddid
ddd
ddd
ddd
ddd
dddddiddiddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddd	dddddd	ddd	ddd	ddd	ddd	dddd
dddddd
ddd
ddd
ddd
ddd
dddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddddiddiddiddiddiddiddidddiddiddiddiddiddiddidddiddiddiddiddiddiddidddiddiddiddiddiddiddidddiddiddiddiddiddiddidddiddiddidd iddiddiddiddd!idd"idd#idd$idd%idd&idd'iddd(idd)iddidd*idd*idd(idd)iddd+iddidd
iddiddiddidd	idddiddidd
iddiddiddidd	id}||  S ),Nr#   z-0.499984740745262)themetintr   r$   z0.39997558519241921)seriesnegativemarkersfirstlasthighlowr%   r&   r'   r(   z-0.249977111117893r   z0.79998168889431442r    z0.499984740745262z0.249977111117893z0.34998626667073579rgbFF323232FFD00000FF000000FF0070C0FF376092FF5F5F5FFFFFB620FFD70077FF5687C2FF359CEBFF56BE79FFFF5055FF777777FFC6EFCEFFFFC7CEFF8CADD6FFFFDC47FFFFEB9CFF60D276FFFF5367FF00B050FFFF0000FFFFC000r"   r   )r   stylesr   r   r   _get_sparkline_style,  s  &/8AJS\enw  
      %  .  7  @  I  R  [  d  m  v     	            $    -    6    ?    H    Rr   dtc                 C   s   t | tjtjtjtjfS N)
isinstancedatetimedatetime	timedelta)r   r   r   r   _supported_datetime  s   r  dt_objremove_timezonec                 C   s&   |r
| j d d} | S | jrtd| S )N)tzinfozExcel doesn't support timezones in datetimes. Set the tzinfo in the datetime/time object to None or use the 'remove_timezone' Workbook() option)r   r  	TypeError)r  r  r   r   r   _remove_datetime_timezone  s   	r
  	date_1904c                 C   s&  | }d}|rt  ddd}nt  ddd}t| t j r%t| |} | | }n9t| t jr8t j |  } | | }n&t| t jrOt j || } t| |} | | }nt| t jrZd}| }nt	d|j
t|jt|jd	  d
  }t|t j rt| t js|  dkr|d8 }|s|s|dkr|d7 }|S )NFip  rz   ik  r@      Tz$Unknown or unsupported datetime typeg    .AiQ )il  rz   rz   ;   )r  r   r
  r  fromordinal	toordinalr  combiner  r	  daysfloatsecondsmicrosecondsisocalendar)r  r  r  	date_typeis_timedeltaepochdelta
excel_timer   r   r   _datetime_to_excel_datetime  sD   






r  c                 C   s   t | p	t| S r   )RE_LEADING_WHITESPACEr   RE_TRAILING_WHITESPACEr   r   r   r   _preserve_whitespace  s   r  )FF)F)0r  r   typingr   r   r   r   warningsr   r   r   r|   __annotations__r   EMOJIScompiler  r  r   r   r   r   r   r   r   r   r   r{   r   r   r   r   r   r   r   r   r   r   r   r  r  r  r
  r  r  r  Matchr  r   r   r   r   <module>   s  
	
 !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVk






#($'
Y "
  V
	

?