a
    Jbg                     @   s   d dl Z d dlZd dlmZ i Ze dZe dZe dZd'ddZ	d	d
 Z
d(ddZdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd  Zd!d" Zd#d$ Zd%d& ZdS ))    N)warnz^\sz\s$z(\$?)([A-Z]{1,3})(\$?)(\d+)Fc                 C   s^   | dk rt d|   dS |dk r0t 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 %d must be >= 0NCol number %d must be >= 0   $ )r   xl_col_to_namestr)rowcolrow_abscol_abscol_str r   1lib/python3.9/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.

    r   )	COL_NAMESr   r   )r	   r
   r   r   r   r   xl_rowcol_to_cell_fast2   s
    
r   c                 C   s   | }|dk rt d|  dS |d7 }d}|r0dnd}|rz|d }|dkrLd}ttd| d }|| }t|d d }q4|| 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   r   Nr   r   r      A)r   chrordint)r
   r   Zcol_numr   Z	remainderZ
col_letterr   r   r   r   G   s    r   c                 C   s   | sdS t | }|d}|d}d}d}t|D ],}|t|td d d|  7 }|d7 }q6t|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         r   r   r   r   re_range_partsmatchgroupreversedr   r   )cell_strr   r   row_strexpnr
   charr	   r   r   r   xl_cell_to_rowcolo   s    


 
r#   c           
      C   s   | sdS t | }|d}|d}|d}|d}|rDd}nd}|rRd}nd}d}d}t|D ],}|t|td	 d d
|  7 }|d7 }qft|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   FFr   r      r   TFr   r   r   r   )
r   r   r   r   r   r    r!   r
   r"   r	   r   r   r   xl_cell_to_rowcol_abs   s*    




 
r%   c                 C   sL   t | |}t ||}|du s$|du r0td dS ||kr<|S |d | 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.

    N#Row and column numbers must be >= 0:r   r   	first_row	first_collast_rowlast_colZrange1Zrange2r   r   r   xl_range   s    

r.   c                 C   sT   t | |dd}t ||dd}|du s,|du r8td dS ||krD|S |d | 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.

    TNr&   r'   r(   r)   r   r   r   xl_range_abs   s    r/   c                 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/   quote_sheetname)	sheetnamer*   r+   r,   r-   Z
cell_ranger   r   r   xl_range_formula   s    r3   c                 C   s*   |   s&| ds&| dd} d|  } | S )z
    Convert a worksheet name to a quoted  name if it contains spaces or
    special characters.

    Args:
       sheetname: The worksheet name. String.

    Returns:
        A quoted worksheet string.

    'z''z'%s')isalnum
startswithreplace)r2   r   r   r   r1   
  s    r1   c                 C   s`   ddddddddd	d
ddddddd}| |v r6||  } t d| sNtd|   d| d  S )Nz#000000z#0000FFz#800000z#00FFFFz#808080z#008000z#00FF00z#FF00FFz#000080z#FF6600z#800080z#FF0000z#C0C0C0z#FFFFFFz#FFFF00)ZblackZblueZbrownZcyanZgrayZgreenZlimeZmagentaZnavyZorangeZpinkZpurpleZredZsilverZwhiteZyellowz#[0-9a-fA-F]{6}z$Color '%s' isn't a valid Excel colorZFF#)rer   r   lstripupper)colorZnamed_colorsr   r   r   xl_color"  s,    r=   c                 C   s   t | }tdd|}|S )Nz^FFr   )r=   r9   sub)r<   Z	rgb_colorr   r   r   get_rgb_colorC  s    r?   c              ,   C   s  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g%}||  S ),N4z-0.499984740745262)themeZtintrA   5z0.39997558519241921)ZseriesnegativeZmarkersfirstZlastZhighZlow6789z-0.2499771111178930z0.799981688894314421z0.499984740745262z0.249977111117893z0.34998626667073579ZrgbZFF323232ZFFD00000ZFF000000ZFF0070C0ZFF376092ZFF5F5F5FZFFFFB620ZFFD70077ZFF5687C2ZFF359CEBZFF56BE79ZFFFF5055ZFF777777ZFFC6EFCEZFFFFC7CEZFF8CADD6ZFFFFDC47ZFFFFEB9CZFF60D276ZFFFF5367ZFF00B050ZFFFF0000ZFFFFC0003r   )Zstyle_idZstylesr   r   r   get_sparkline_styleM  s\       -rL   c                 C   s   t | tjtjtjtjfS )N)
isinstancedatetimedatetime	timedelta)Zdtr   r   r   supported_datetime|  s
    rR   c                 C   s$   |r| j d d} n| 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)r7   rS   	TypeError)dt_objremove_timezoner   r   r   remove_datetime_timezone  s    rW   c                 C   s   | }d}|rt  ddd}nt  ddd}t| t j rJt| |} | | }nrt| t jrpt j |  } | | }nLt| t jrt j || } t| |} | | }nt| t jrd}| }nt	d|j
t|jt|jd	  d
  }t|t j r|  dkr|d8 }|s|s|dkr|d7 }|S )NFip  r   ik        Tz$Unknown or unsupported datetime typeg    .AiQ )il  r   r   ;   )rN   rM   rW   rO   ZfromordinalZ	toordinalrP   ZcombinerQ   rT   ZdaysfloatZsecondsZmicrosecondsZisocalendar)rU   Z	date_1904rV   Z	date_typeZis_timedeltaZepochZdeltaZ
excel_timer   r   r   datetime_to_excel_datetime  sB    





r\   c                 C   s    t | st| rdS dS d S )NTF)
re_leadingsearchre_trailing)stringr   r   r   preserve_whitespace  s    ra   )FF)F)r9   rN   warningsr   r   compiler]   r_   r   r   r   r   r#   r%   r.   r/   r3   r1   r=   r?   rL   rR   rW   r\   ra   r   r   r   r   <module>   s0   




( .!
  14