U
    [eg9                     @   s  d dl Z d dlmZ d dlZd dlZd dlZd dlZd dlm	Z	 d dl
mZ d dlmZmZ edZejddgZdd	 Zd
d Zejdddgdd Zejdddgdd Zdd Zejdddgdd Zejdddgfddddgfgd d! Zejd"d#d$d%d&gfd'd(d)gfd*d(d)d&gfgd+d, Zejd-d d d.d/gd0d1gfd d(d2d/gd.d1gfd(d d2d.gd0d1gfd(d(d2d/gd0d.gfgd3d4 Zejd5d6d7d8gd9d: Zd;d< Zejd=ddgd>d? Z ejd@d ej!dAd(d$dBgej!dCdDdEdFgej!dGdHdIdJgdKfd$d(d$dBgdDdEdFgdHdIdJgdLfgejdMdNdOdPgejd=dddgdQdR Z"dSdT Z#ejd=dddgdUdV Z$ejd=dddgdWdX Z%dYdZ Z&d[d\ Z'd]d^ Z(dS )_    N)Path)	DataFrame)ExcelWriter_OpenpyxlWriteropenpyxlextz.xlsxc                 C   s4  ddl m} dddddddddd	d
dddddddidddd}|d}|jd|d}|j|jjd}|j||||d}|jdd	d
}|jddd}|j	d|d}	d}
|j
ddd}t|}|d |kst|d |kst|d |kst|d |	kst|d |
kst|d |ks0td S )Nr   )styles00FF0000TcolorboldZthin)toprightbottomleftcenterr   )
horizontalverticalZsolidZ006666FFg333333?)rgbZtint)ZpatternTypeZfgColorZformat_codez0.00F)lockedZhidden)fontborders	alignmentfillnumber_format
protection)r   r   )styler   borderr   r   r   r   )r   r   ColorZFontZSider   ZBORDER_THINZBorderZ	AlignmentZPatternFillZ
Protectionr   _convert_to_style_kwargsAssertionError)r   r   ZhstyleZ
font_colorr   Zsider   r   Z
fill_colorr   r   r   kw r"   e/var/www/html/services/stratfitenv/lib/python3.8/site-packages/pandas/tests/io/excel/test_openpyxl.pytest_to_excel_styleconverter   s0    	

r$   c              
   C   s   ddl m} d}dddii}dddii}|ddd	|d
|ddd|d
g}ddddi}t|}|d }|ddddd|dg}	t| l}
t|
,}|j||d |j|	|d |j| }W 5 Q R X |d }|d }|j|kst	|j|kst	W 5 Q R X d S )Nr   )	ExcelCellZmerge_styledr   r   r	   Z0000FF00   *   )colrowvalr   c   Z000000FFTr
   pandas)r(   r)   r*   Z
mergestartZmergeendr   
sheet_nameB1A2)
Zpandas.io.formats.excelr%   r   r   tmensure_cleanZ_write_cellssheetsr   r    )r   r%   r.   Zsty_b1Zsty_a2Zinitial_cellsZ
sty_mergedZ
sty_kwargsZopenpyxl_sty_mergedZmerge_cellspathwriterZwksZxcell_b1Zxcell_a2r"   r"   r#   test_write_cells_merge_styled7   s8    
     
r6   	iso_datesTFc                 C   s   d|i}t | f}td}t jt|dB t|fddi|"}|jj|ksTt	t
 | W 5 Q R X W 5 Q R X W 5 Q R X d S )Nr7   zUse of **kwargs is deprecatedmatchenginer   )r1   r2   reescapeZassert_produces_warningFutureWarningr   bookr7   r    r   to_excel)r   r7   kwargsfmsgr5   r"   r"   r#   test_kwargsY   s    
rC   c              
   C   sX   d|i}t | <}t|d|d"}|jj|ks4tt | W 5 Q R X W 5 Q R X d S )Nr7   r   )r:   engine_kwargs)r1   r2   r   r>   r7   r    r   r?   )r   r7   rD   rA   r5   r"   r"   r#   test_engine_kwargs_writef   s
    rE   c                 C   s   t | l}tddg| tjttdd: t	|ddddid	}td
gj|dd W 5 Q R X W 5 Q R X W 5 Q R X d S )NhelloworldzAload_workbook() got an unexpected keyword argument 'apple_banana'r8   r   aZapple_bananafruitr:   moderD   ZgoodSheet2r-   )
r1   r2   r   r?   pytestraises	TypeErrorr;   r<   r   )r   rA   r5   r"   r"   r#   !test_engine_kwargs_append_invalidq   s        rP   zdata_only, expected)Tr   )F=1+1c              
   C   sr   t | ^}tdg| t|ddd|id.}|jd d j|ksJtt j|dd	 W 5 Q R X W 5 Q R X d S )
NrQ   r   rH   	data_onlyrJ   ZSheet1B2rL   r-   )r1   r2   r   r?   r   r3   valuer    )r   rR   expectedrA   r5   r"   r"   r#   #test_engine_kwargs_append_data_only   s       rV   zmode,expectedwbazrH   foobarc              
   C   s   t dgdgd}t| }t }d|jd _d|jd d _|d d|jd d _|	| t
|d|d	}|j|dd
d W 5 Q R X tt|L}dd |jD }||kstt|D ] \}	}
|j|	 d j|
kstqW 5 Q R X W 5 Q R X d S )Nr&   rX   columnsrY   r   A1rZ   r   )r:   rK   Fr.   indexc                 S   s   g | ]
}|j qS r"   )title).0sheetr"   r"   r#   
<listcomp>   s     z*test_write_append_mode.<locals>.<listcomp>)r   r1   r2   r   ZWorkbookZ
worksheetsr`   rT   create_sheetsaver   r?   
contextlibclosingload_workbookr    	enumerate)r   rK   rU   dfrA   wbr5   Zwb2resultr_   Z
cell_valuer"   r"   r#   test_write_append_mode   s    

rm   z#if_sheet_exists,num_sheets,expectednew   applebananareplacer&   pearoverlayc           
   
   C   s
  t dddgi}t ddgi}t| }|j|dddd t|dd	|d
}|j|ddd W 5 Q R X tt|~}t	|j
|kst|j
d dksttj|ddd}	t|	d |kstt	|j
dkrtj||j
d dd}	t|	| W 5 Q R X W 5 Q R X d S )NrI   rp   rq   rs   r   rY   Fr:   r.   r_   rH   r:   rK   if_sheet_existsr^   r   r:   ro   r&   )r   r1   r2   r?   r   rf   rg   r   rh   lenZ
sheetnamesr    pd
read_excellistassert_frame_equal)
r   rw   Z
num_sheetsrU   df1df2rA   r5   rk   rl   r"   r"   r#   !test_if_sheet_exists_append_modes   s(    
   r   z%startrow, startcol, greeting, goodbyepooprG   goodbyepeoplerF   c              
   C   s   t ddgddgd}t dg}t| x}|j|ddd	d
 t|dddd }|j|d	d	|d |dd W 5 Q R X tj|ddd}	t ||d}
t|	|
 W 5 Q R X d S )NrF   rG   r   r   )greetingr   r   r   ZpooFru   rH   rt   rv   r&   )r_   headerstartrowstartcolr.   )r.   r:   )r   r1   r2   r?   r   rz   r{   r}   )r   r   r   r   r   r~   r   rA   r5   rl   rU   r"   r"   r#   %test_append_overlay_startrow_startcol   s,    

   	r   zif_sheet_exists,msg)invalidzf'invalid' is not valid for if_sheet_exists. Valid options are 'error', 'new', 'replace' and 'overlay'.)errorASheet 'foo' already exists and if_sheet_exists is set to 'error'.)Nr   c                 C   s   t ddgi}t| `}tjtt|d@ |j|ddd t	|dd|d}|j|dd	 W 5 Q R X W 5 Q R X W 5 Q R X d S )
NrI   rs   r8   rY   r   rx   rH   rv   r-   )
r   r1   r2   rM   rN   
ValueErrorr;   r<   r?   r   )r   rw   rB   rj   rA   r5   r"   r"   r#   test_if_sheet_exists_raises   s       r   c              	   C   sz   t | f}tdtdddi}tdtdddi}tj||gdd}|jdd 	 }|j
|d	d
 W 5 Q R X d S )NAr&   
   B   )Zaxisc                 S   s   d| dk rdnd S )Nz	color: %sr   redblackr"   )r*   r"   r"   r#   <lambda>      z4test_to_excel_with_openpyxl_engine.<locals>.<lambda>r   rx   )r1   r2   r   npZlinspacerz   concatr   ZapplymapZhighlight_maxr?   )r   filenamer~   r   rj   styledr"   r"   r#   "test_to_excel_with_openpyxl_engine  s    r   	read_onlyc              	   C   sZ   | dddd| }t tj||d}tj|dd}W 5 Q R X t|}t|| d S )NiodataexcelZtest1r   r   rx   )rf   rg   r   rh   rz   r{   r1   r}   )datapathr   r   r   rk   rl   rU   r"   r"   r#   test_read_workbook  s    
r   zheader, expected_datar      r            C      	   ZTitlez
Unnamed: 1z
Unnamed: 2)r   r   r   r   Zdimension_missingZdimension_smallZdimension_largec           
   	   C   sv   | ddd| | }|d kr.t j||d}n0ttj||d}t j|d|d}W 5 Q R X t|}	t||	 d S )Nr   r   r   )r   r   r   )r:   r   	rz   r{   rf   rg   r   rh   r   r1   r}   )
r   r   r   Zexpected_datar   r   r4   rl   rk   rU   r"   r"   r#   test_read_with_bad_dimension"  s    r   c              
   C   s   t  }t| }|j|dd t|dddd}|| W 5 Q R X t| }|d}|d|d }|d|d }|dkr|dkstW 5 Q R X d S )	Nr   rx   rH   rn   )rK   r:   rw   s   docProps/app.xmlr&   )	r   r1   r2   r?   r   r   
read_bytesfindr    )r   rj   rA   r5   r   firstsecondthirdr"   r"   r#   test_append_mode_fileE  s        
r   c              	   C   s   | dddd| }|d kr(t |}n.ttj||d}t j|dd}W 5 Q R X ttjdd	d
dgtjddddgtjddddgd}t	
|| d S )Nr   r   r   Zempty_trailing_rowsr   r   rx   r   r&   ro   r   r   r   r   r   r   r   r   r   r   )rz   r{   rf   rg   r   rh   r   r   nanr1   r}   r   r   r   r4   rl   rk   rU   r"   r"   r#   "test_read_with_empty_trailing_rows[  s    r   c              	   C   sl   | dddd| }|d kr(t |}n.ttj||d}t j|dd}W 5 Q R X t }t|| d S )Nr   r   r   Zempty_with_blank_rowr   r   rx   r   r   r"   r"   r#   test_read_empty_with_blank_rowq  s    r   c              
   C   s`   t | L}t|dd4}|ji ks(t|jdd}|jd|iksHtW 5 Q R X W 5 Q R X d S )Nr   rx   Z	test_namer   )r1   r2   r   r3   r    r>   rd   )r   rA   r5   rb   r"   r"   r#   test_book_and_sheets_consistent  s
    r   c                 C   sB   | dddd| }t |}ttdddgd}t|| d S )	Nr   r   r   Zints_spelled_with_decimalsro      r&   r[   )rz   r{   r   ranger1   r}   r   r   r4   rl   rU   r"   r"   r#   test_ints_spelled_with_decimals  s    
r   c                 C   s   | dddd| }t j|dddgdddgd}ttjd	d	d	gd	tjtjtjggt jd
dddgt jddgd}t|| d S )Nr   r   r   Zmultiindex_no_index_namesr   r&   ro   )Z	index_colr   x)XYr]   )r   r   r0   )XXYYr/   )r   r   rS   )r   ZAAZAAA)r   BBZBBB)r\   r_   )	rz   r{   r   r   r   Z
MultiIndexfrom_tuplesr1   r}   r   r"   r"   r#   *test_read_multiindex_header_no_index_names  s    
r   ))rf   pathlibr   r;   numpyr   rM   r,   rz   r   Zpandas._testingZ_testingr1   Zpandas.io.excelr   r   Zimportorskipr   markZparametrizeZ
pytestmarkr$   r6   rC   rE   rP   rV   rm   r   r   r   r   r   r   r   r   r   r   r   r   r   r"   r"   r"   r#   <module>   s   
!"



 


	


  

	