U
    >v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rightZbottomleftcenterr   )Z
horizontalZverticalZsolidZ006666FFg333333?)ZrgbZtint)ZpatternTypeZfgColorZformat_codez0.00F)lockedhidden)fontborders	alignmentfillnumber_format
protection)r   r   )styler   borderr   r   r   r   )r   r   Z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   G/tmp/pip-unpacked-wheel-vdrwu74i/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    
     
r2   	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 )Nr3   r   )engineengine_kwargs)r-   r.   r   bookr3   r   r   to_excel)r   r3   r5   fr1   r   r   r   test_engine_kwargs_writeY   s
    r9   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r4   moder5   ZgoodSheet2r)   )
r-   r.   r   r7   pytestraises	TypeErrorreescaper   )r   r8   r1   r   r   r   !test_engine_kwargs_append_invalidd   s        rH   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 )
NrI   r   r>   	data_onlyr@   ZSheet1B2rB   r)   )r-   r.   r   r7   r   r/   valuer   )r   rJ   expectedr8   r1   r   r   r   #test_engine_kwargs_append_data_onlyv   s       rN   zmode,expectedwbazr>   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"   rP   columnsrQ   r   A1rR   r   )r4   rA   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   r-   r.   r   ZWorkbookZ
worksheetsrX   rL   create_sheetsaver   r7   
contextlibclosingload_workbookr   	enumerate)r   rA   rM   dfr8   wbr1   Zwb2resultrW   Z
cell_valuer   r   r   test_write_append_mode   s    

re   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 )Nr?   rh   ri   rk   r   rQ   Fr4   r*   rW   r>   r4   rA   if_sheet_existsrV   r   r4   rg   r"   )r   r-   r.   r7   r   r^   r_   r   r`   lenZ
sheetnamesr   pd
read_excellistassert_frame_equal)
r   ro   Z
num_sheetsrM   df1df2r8   r1   rc   rd   r   r   r   !test_if_sheet_exists_append_modes   s(    
   rx   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;   rz   r{   )greetingrz   ry   r   ZpooFrm   r>   rl   rn   r"   )rW   headerstartrowstartcolr*   )r*   r4   )r   r-   r.   r7   r   rr   rs   ru   )r   r~   r   r|   rz   rv   rw   r8   r1   rd   rM   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 )
Nr?   rk   r<   rQ   r   rp   r>   rn   r)   )
r   r-   r.   rC   rD   
ValueErrorrF   rG   r7   r   )r   ro   msgrb   r8   r1   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   ZredZblackr   )r&   r   r   r   <lambda>      z4test_to_excel_with_openpyxl_engine.<locals>.<lambda>r   rp   )r-   r.   r   npZlinspacerr   concatr   ZapplymapZhighlight_maxr7   )r   filenamerv   rw   rb   Z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   rp   )r^   r_   r   r`   rr   rs   r-   ru   )datapathr   r   r   rc   rd   rM   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   )r4   r}   	rr   rs   r^   r_   r   r`   r   r-   ru   )
r   r   r}   Zexpected_datar   r   r0   rd   rc   rM   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   rp   r>   rf   )rA   r4   ro   s   docProps/app.xmlr"   )	r   r-   r.   r7   r   r   
read_bytesfindr   )r   rb   r8   r1   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   rp   r   r"   rg   r   r   r   r   r   r   r   r   r   r   )rr   rs   r^   r_   r   r`   r   r   nanr-   ru   r   r   r   r0   rd   rc   rM   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   rp   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   rp   Z	test_namer   )r-   r.   r   r/   r   r6   r\   )r   r8   r1   rZ   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_decimalsrg      r"   rS   )rr   rs   r   ranger-   ru   r   r   r0   rd   rM   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"   rg   )Z	index_colr}   x)XYrU   )r   r   r,   )XXYYr+   )r   r   rK   )r   ZAAZAAA)r   BBZBBB)rT   rW   )	rr   rs   r   r   r   Z
MultiIndexfrom_tuplesr-   ru   r   r   r   r   *test_read_multiindex_header_no_index_names  s    
r   )(r^   pathlibr   rF   Znumpyr   rC   r(   rr   r   Zpandas._testingZ_testingr-   Zpandas.io.excelr   r   Zimportorskipr   markZparametrizeZ
pytestmarkr    r2   r9   rH   rN   re   rx   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   <module>   s   
!"

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