U
    _{f-7                     @   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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d.d/gfd d&d0d-gd,d/gfd&d d0d,gd.d/gfd&d&d0d-gd.d,gfgd1d2 Zejd3d4d5d6gd7d8 Zd9d: Zejd;ddgd<d= Zejd>d ej d?d&d"d@gej dAdBdCdDgej dEdFdGdHgdIfd"d&d"d@gdBdCdDgdFdGdHgdJfgejdKdLdMdNgejd;dddgdOdP Z!dQdR Z"ejd;dddgdSdT Z#ejd;dddgdUdV Z$dWdX Z%dYdZ 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"   b/var/www/html/Darija-Ai-API/env/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   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   )engineengine_kwargs)r1   r2   r   bookr7   r    r   to_excel)r   r7   r9   fr5   r"   r"   r#   test_engine_kwargs_writeY   s
    r=   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'matchr   aZapple_bananafruitr8   moder9   ZgoodSheet2r-   )
r1   r2   r   r;   pytestraises	TypeErrorreescaper   )r   r<   r5   r"   r"   r#   !test_engine_kwargs_append_invalidd   s        rL   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 )
NrM   r   rB   	data_onlyrD   ZSheet1B2rF   r-   )r1   r2   r   r;   r   r3   valuer    )r   rN   expectedr<   r5   r"   r"   r#   #test_engine_kwargs_append_data_onlyv   s       rR   zmode,expectedwbazrB   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&   rT   columnsrU   r   A1rV   r   )r8   rE   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\   rP   create_sheetsaver   r;   
contextlibclosingload_workbookr    	enumerate)r   rE   rQ   dfr<   wbr5   Zwb2resultr[   Z
cell_valuer"   r"   r#   test_write_append_mode   s    

ri   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 )NrC   rl   rm   ro   r   rU   Fr8   r.   r[   rB   r8   rE   if_sheet_existsrZ   r   r8   rk   r&   )r   r1   r2   r;   r   rb   rc   r   rd   lenZ
sheetnamesr    pd
read_excellistassert_frame_equal)
r   rs   Z
num_sheetsrQ   df1df2r<   r5   rg   rh   r"   r"   r#   !test_if_sheet_exists_append_modes   s(    
   r|   z%startrow, startcol, greeting, goodbyepoopr?   goodbyepeopler>   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 )Nr>   r?   r~   r   )greetingr~   r}   r   ZpooFrq   rB   rp   rr   r&   )r[   headerstartrowstartcolr.   )r.   r8   )r   r1   r2   r;   r   rv   rw   ry   )r   r   r   r   r~   rz   r{   r<   r5   rh   rQ   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 )
NrC   ro   r@   rU   r   rt   rB   rr   r-   )
r   r1   r2   rG   rH   
ValueErrorrJ   rK   r;   r   )r   rs   msgrf   r<   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: r   redblackr"   )r*   r"   r"   r#   <lambda>      z4test_to_excel_with_openpyxl_engine.<locals>.<lambda>r   rt   )r1   r2   r   npZlinspacerv   concatr   ZapplymapZhighlight_maxr;   )r   filenamerz   r{   rf   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   rt   )rb   rc   r   rd   rv   rw   r1   ry   )datapathr   r   r   rg   rh   rQ   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   )r8   r   	rv   rw   rb   rc   r   rd   r   r1   ry   )
r   r   r   Zexpected_datar   r   r4   rh   rg   rQ   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   rt   rB   rj   )rE   r8   rs   s   docProps/app.xmlr&   )	r   r1   r2   r;   r   r   
read_bytesfindr    )r   rf   r<   r5   r   firstsecondthirdr"   r"   r#   test_append_mode_file7  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   rt   r   r&   rk   r   r   r   r   r   r   r   r   r   r   )rv   rw   rb   rc   r   rd   r   r   nanr1   ry   r   r   r   r4   rh   rg   rQ   r"   r"   r#   "test_read_with_empty_trailing_rowsM  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   rt   r   r   r"   r"   r#   test_read_empty_with_blank_rowc  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   rt   Z	test_namer   )r1   r2   r   r3   r    r:   r`   )r   r<   r5   r^   r"   r"   r#   test_book_and_sheets_consistentr  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_decimalsrk      r&   rW   )rv   rw   r   ranger1   ry   r   r   r4   rh   rQ   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&   rk   )Z	index_colr   x)XYrY   )r   r   r0   )XXYYr/   )r   r   rO   )r   ZAAZAAA)r   BBZBBB)rX   r[   )	rv   rw   r   r   r   Z
MultiIndexfrom_tuplesr1   ry   r   r"   r"   r#   *test_read_multiindex_header_no_index_names  s    
r   )(rb   pathlibr   rJ   numpyr   rG   r,   rv   r   Zpandas._testingZ_testingr1   Zpandas.io.excelr   r   Zimportorskipr   markZparametrizeZ
pytestmarkr$   r6   r=   rL   rR   ri   r|   r   r   r   r   r   r   r   r   r   r   r   r   r"   r"   r"   r#   <module>   s   
!"

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