U
    +if+                  	   @   s  d dl m Z mZ d dlmZ d dlZd dlmZ d dlmZ d dl	m
Z
 d dlZd dlZd dlm  mZ d dlZd dlmZmZmZmZ d dlmZ d dlmZ d d	lmZ d
ddddgZej de!dgdej de!dej"#dgdej de!dgdej de!ddej de!ddgZ$e%e&dddZ'dd Z(ej)dd e$D ddd Z*ej)dd  Z+ej)d!d" Z,G d#d$ d$Z-G d%d& d&Z.dS )'    )datetimetime)partialNPath)URLError)
BadZipFile)	DataFrameIndex
MultiIndexSeries)xlrd_version)Version.xls.xlsx.xlsm.xlsb.odsxlrdmarksopenpyxlzignore:.*html argumentpyxlsbodf)read_extreturnc                 C   s   | j d } | dkr|dkrdS | dkr2|dkr2dS |dkrF| dkrFdS | dkrZ|dkrZdS |dkrn| dkrndS | d	krtd
k	rttdkr|dkrdS dS )zm
    Filter out invalid (engine, ext) pairs instead of skipping, as that
    produces 500+ pytest.skips.
    r   r   r   Fr   r   r   r   r   N2T)valuesr   r   )enginer    r   U/home/mars/bis/venv/lib/python3.8/site-packages/pandas/tests/io/excel/test_readers.py_is_valid_engine_ext_pair8   s*    

r!   c                 C   s    | j |f }tj|| jd}|S )z
    engine gives us a pytest.param object with some marks, read_ext is just
    a string.  We need to generate a new pytest.param inheriting the marks.
    r   )r   pytestparamr   )r   r   r   	new_paramr   r   r    _transfer_marksR   s    r%   c                 C   s*   g | ]"}t D ]}t||rt||qqS r   )read_ext_paramsr!   r%   ).0Zengextr   r   r    
<listcomp>]   s
    
r)   )paramsc                 C   s   | j S )zS
    Fixture for Excel reader engine and read_ext, only including valid pairs.
    )r#   )requestr   r   r    engine_and_read_ext\   s    r,   c                 C   s   | \}}|S Nr   r,   r   r   r   r   r    r   k   s    r   c                 C   s   | \}}|S r-   r   r.   r   r   r    r   q   s    r   c                   @   s  e Zd Zejdddd Zdd Zdd Zd	d
 Zdd Z	ej
ddddgdddgdddgdddgdddgdddggdd Zej
dddgddggdd Zdd Zdd Zdd Zdd Zdd  Zej
d!d"d#gd$d% Zd&d' Zd(d) Zd*d+ Zd,d- Zd.d/ Zd0d1 Zd2d3 Zd4d5 Zej
d6d"edd#dd7gd8d9d:d;gdd#dd7gd<d=ejd>gd?fd@dAeed?ee dd#dd7gd@dBe d8d9d:d;gdAdBdCdDdEdFgdGdHejdIgd?fgdJdK Z!ej
dLi dGfdMdNidfgdOdP Z"dQdR Z#ej
dSdTedUdVgifdWedXgdYfgdZd[ Z$d\d] Z%d^d_ Z&d`da Z'dbdc Z(ddde Z)dfdg Z*dhdi Z+djdk Z,dldm Z-ej
dndddgddgdodpdogdodpggdqdr Z.dsdt Z/dudv Z0ej
j1e2j1dwddxdydz Z3e4j5ej
j6d{d| Z7ej
j6d}d~ Z8ej
j9dd Z:dd Z;e4<de4j=dd Z>e4j=dd Z?dd Z@dd ZAej
ddejdddgfdejgd7 fgdd ZBdd ZCdd ZDdd ZEdd ZFdd ZGdd ZHdd ZIdd ZJdd ZKdd ZLdd ZMdd ZNdd ZOdd ZPdd ZQdd ZRd"S )TestReadersTZautousec                 C   s2   t tj|d}||ddd |td| dS )zG
        Change directory and set engine for read_excel calls.
        r   iodataexcel
read_excelN)r   pdr5   chdirsetattrselfr   datapathmonkeypatchfuncr   r   r    cd_and_set_enginex   s    zTestReaders.cd_and_set_enginec           	   	   C   sz   dd }| tjd| dddddd}td	| d
}t|}W 5 Q R X |d k	rZ|}n||dd   }||ksvtd S )Nc                 _   s   | j S r-   r1   )r:   argskwargsr   r   r    parser   s    z,TestReaders.test_engine_used.<locals>.parserparser   r   r   r   xlsxZxlsmZxlsbxlsZodstest1rb   )r8   r6   	ExcelFileopenr5   AssertionError)	r:   r   r   r<   rA   expected_defaultsfresultexpectedr   r   r    test_engine_used   s    zTestReaders.test_engine_usedc              	   C   sl   d}t jt|d tjd| dddd W 5 Q R X t jt|d  tjd| dd	gddd
 W 5 Q R X d S )Nz Passing an integer for `usecols`matchrF   Sheet1r      
sheet_name	index_colusecolsSheet2rH   rV   skiprowsrW   rX   r"   raises
ValueErrorr6   r5   r:   r   msgr   r   r    test_usecols_int   s        zTestReaders.test_usecols_intc                 C   s   |dkr|j tjjdd |jddgd}tjd| dd	d	d
dgd}tjd| ddgd	d	d
dgd}tj	||dd tj	||dd d S )Nr   3Sheets containing datetimes not supported by pyxlsbreasonBCcolumnsrF   rS   r      rT   rU   rY   rH   rZ   FZcheck_names
node
add_markerr"   markxfailreindexr6   r5   tmassert_frame_equal)r:   r+   r   df_refdf1df2r   r   r    test_usecols_list   s,       	zTestReaders.test_usecols_listc                 C   sD  |dkr|j tjjdd |jdddgd}tjd| d	d
dd}tjd| ddgd
dd}tj	||dd tj	||dd |jddgd}tjd| d	d
dd}tjd| ddgd
dd}tj	||dd tj	||dd |jddgd}tjd| d	d
dd}tjd| ddgd
dd}tj	||dd tj	||dd d S )Nr   rb   rc   Are   rf   rg   rF   rS   r   zA:DrU   rY   rH   rZ   Frj   zA,C,DzA,C:Drk   r:   r+   r   rs   rt   ru   df3r   r   r    test_usecols_str   sl       	      zTestReaders.test_usecols_strrX   r   rH   rT   c                 C   sT   |dkr|j tjjdd |ddg }tjd| dd|d	}tj||d
d d S )Nr   rb   rc   rw   rf   rF   rS   r   rU   Frj   	rl   rm   r"   rn   ro   r6   r5   rq   rr   )r:   r+   r   rX   rs   rO   rN   r   r   r    .test_usecols_diff_positional_int_columns_order   s       z:TestReaders.test_usecols_diff_positional_int_columns_orderre   Dc                 C   sB   |ddg }t t||_tjd| d|d}tj||dd d S )Nre   r}   rF   rS   rV   rX   Frj   )rangelenindexr6   r5   rq   rr   )r:   r   rX   rs   rO   rN   r   r   r    .test_usecols_diff_positional_str_columns_order  s    z:TestReaders.test_usecols_diff_positional_str_columns_orderc                 C   sJ   |dkr|j tjjdd |}tjd| ddd}tj||dd	 d S )
Nr   rb   rc   rF   rS   r   rV   rW   Frj   r{   r:   r+   r   rs   rO   rN   r   r   r    test_read_excel_without_slicing  s    z+TestReaders.test_read_excel_without_slicingc                 C   sT   |dkr|j tjjdd |ddg }tjd| ddd	d
}tj||dd d S )Nr   rb   rc   rf   r}   rF   rS   r   zA,D:ErU   Frj   r{   r   r   r   r    test_usecols_excel_range_str  s       z(TestReaders.test_usecols_excel_range_strc              	   C   s6   d}t jt|d tjd| ddd W 5 Q R X d S )NzInvalid column name: E1rQ   rF   rS   zD:E1r~   r\   r_   r   r   r    $test_usecols_excel_range_str_invalid-  s    z0TestReaders.test_usecols_excel_range_str_invalidc              	   C   s>   d}t jt|d" tjd| ddgddgd W 5 Q R X d S )Nz(list indices must be integers.*, not strrQ   rF   rS   rw   rf   rU   r"   r]   	TypeErrorr6   r5   r_   r   r   r    test_index_col_label_error3  s    z&TestReaders.test_index_col_label_errorc                 C   sX   t jd| ddddgd}tddd	gtg gd
 g gd
 dddgdd}t|| d S )NrF   Sheet3rw   re   rf   r   r}   EFrT   Zlevelscodesnamesrh   r   )r6   r5   r	   r   rq   rr   )r:   r   rN   rO   r   r   r    test_index_col_empty>  s      z TestReaders.test_index_col_emptyrW   Nri   c                 C   sZ   t jd| d|d}tdddgddd	ggd
ddgd}|rJ||j| }t|| d S )NrF   Sheet4r   i1axi2byz
Unnamed: 0Zcol1Zcol2rg   )r6   r5   r	   	set_indexrh   rq   rr   )r:   r   rW   rN   rO   r   r   r    test_index_col_with_unnamedI  s       z'TestReaders.test_index_col_with_unnamedc              	   C   s6   d}t jt|d tjd| dgd W 5 Q R X d S )NzEUsecols do not match columns, columns expected but not found: \['E'\]rQ   rF   r   rX   r\   r_   r   r   r    %test_usecols_pass_non_existent_columnW  s    z1TestReaders.test_usecols_pass_non_existent_columnc              	   C   s8   d}t jt|d tjd| ddgd W 5 Q R X d S )Nz['usecols' must either be list-like of all strings, all unicode, all integers or a callable.rQ   rF   ZE1r   r   r\   r_   r   r   r    test_usecols_wrong_type`  s    z#TestReaders.test_usecols_wrong_typec                 C   s8   t jd| dd}tddggddgd}t|| d S )	NZtest2rS   rV   ZaaaaZbbbbbTestZTest1rg   r6   r5   r	   rq   rr   )r:   r   parsedrO   r   r   r    test_excel_stop_iteratori  s    z$TestReaders.test_excel_stop_iteratorc                 C   sT   |dkr|j tjjdd tjd| dd}ttj	ggdgd}t
|| d S )	Nr   rb   rc   Ztest3rS   r   r   rg   )rl   rm   r"   rn   ro   r6   r5   r	   npnanrq   rr   )r:   r+   r   r   rO   r   r   r    test_excel_cell_error_nao  s    z$TestReaders.test_excel_cell_error_nac                 C   s   |dkr|j tjjdd tjd| ddd}tjd| dd	gdd
}tj||dd tj||dd tjd| ddd	d}t||j	d d  d S )Nr   rb   rc   rF   rS   r   r   rY   rH   rV   r[   rW   Frj   rV   rW   
skipfooter)
rl   rm   r"   rn   ro   r6   r5   rq   rr   ilocrx   r   r   r    test_excel_table{  s,          zTestReaders.test_excel_tablec                 C   s  |dkr|j tjjdd tdddddgd	d
dddgdddddgdddddgdddddgtdddtdddtdddtdddtdddgd}d}tj	|| d d!}t
|| | }|d" t|d"< d#|j|jd d$f< t
jtd%dd& tj	|| d dd'}W 5 Q R X t
|| t|jD ]4\}}tj	|| d |d(}||}	t
||	 q0|d) t|d)< tj	|| d d)tid*}t
|| | }
|
d) t|
d)< t
jtd%dd&  tj	|| d dd)tid+}W 5 Q R X t
||
 d S ),Nr   rb   rc   rH   ri      r   g      ?g      @gHzG?gQ?g&.>TFrT      r   cdei  
         iq        i  )IntColFloatColBoolColStrColStr2ColZDateColZ
test_typesrS   r   r   g      @r   zconvert_float is deprecated)rR   raise_on_extra_warnings)rV   convert_floatr   r   rV   
converters)rV   r   r   )rl   rm   r"   rn   ro   r	   	from_dictr   r6   r5   rq   rr   copyastypefloatlocr   assert_produces_warningFutureWarning	enumeraterh   r   applystr)r:   r+   r   rO   basenameactualZfloat_expectedZicolnameexpZno_convert_floatr   r   r    test_reader_special_dtypes  s    




    
  z&TestReaders.test_reader_special_dtypesc              
   C   s   d}t dddddgdtjdd	d
gdddddgdtjdddgd}dd dd dd dd d}tj|| d|d}t|| d S )NZtest_convertersrH   ri   r   r   g      )@gL2@g3333333@g:0y5>Found	Not found1345)r   r   r   r   c                 S   s   | dkrt | S dS )N r   )intr   r   r   r    <lambda>      z4TestReaders.test_reader_converters.<locals>.<lambda>c                 S   s   | rd|  S t jS )Nr   )r   r   r   r   r   r    r     r   c                 S   s   | dkrdS dS )Nr   r   r   r   r   r   r   r    r     r   c                 S   s   | rt | S dS )Nr   )r   r   r   r   r    r     r   )r   r   ri   rT   rS   r   )r	   r   r   r   r6   r5   rq   rr   )r:   r   r   rO   r   r   r   r   r    test_reader_converters  s&    
	  z"TestReaders.test_reader_convertersc              	   C   s   d}t || }tddddgdddd	gddddgd
dtjdgdjddddgd}t|| t j|| ddtdd}|d 	d|d< |d 	d|d< ddddg|d< t|| d}t
jt|d t j|| ddid W 5 Q R X d S )N	testdtyperH   ri   rT   r         @      @      @      @      ?       @      @r   r   r   r   r   r   r   r   rg   float64float32)r   r   r   dtype001002003004z(Unable to convert column d to type int64rQ   int64)r6   r5   r	   r   r   rp   rq   rr   r   r   r"   r]   r^   )r:   r   r   r   rO   r`   r   r   r    test_reader_dtype  s.    



	 
zTestReaders.test_reader_dtypezdtype,expectedr   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   c                 C   s&   d}t j|| |d}t|| d S )Nr   r   r6   r5   rq   rr   )r:   r   r   rO   r   r   r   r   r    test_reader_dtype_str  s    z!TestReaders.test_reader_dtype_strzdtypes, exp_valuea.1r   c           	      C   s\   d}dt i|}| }tj|| |d}tdg|gd}||ksLtdt|| d S )NZdf_mangle_dup_col_dtypesr   r   r   )r   r   zdtype dict changed)r   r   r6   r5   r	   rK   rq   rr   )	r:   r   ZdtypesZ	exp_valuer   Z
dtype_dictZdtype_dict_copyrN   rO   r   r   r    test_dtype_mangle_dup_cols<  s    z&TestReaders.test_dtype_mangle_dup_colsc                 C   s8   d}t || }tddddddgi}t|| d S )NZtest_spacesZtestcolzthis is greatz4    spacesz1 trailing z
 1 leadingz2  spaces  multiple  timesr   )r:   r   r   r   rO   r   r   r    test_reader_spacesH  s    zTestReaders.test_reader_spaceszbasename,expectedzgh-35802ZCOLUMNzTest (1)zgh-36122z
got 2nd sarg   c                 C   s6   |dkrt d|  t|| }t|| d S )Nr   zSkipped for engine: )r"   skipr6   r5   rq   rr   )r:   r   r   r   rO   r   r   r   r    test_read_excel_ods_nested_xml[  s    	z*TestReaders.test_read_excel_ods_nested_xmlc                 C   sH   d}t j|| d d}dddg}t||  |t| ksDtd S )Ntest_multisheetr   CharlieAlphaBeta)r6   r5   rq   assert_contains_allkeyslistrK   r:   r   r   dfsexpected_keysr   r   r    test_reading_all_sheetsj  s
    
z#TestReaders.test_reading_all_sheetsc                 C   sX   d}dddg}t j|| |d}tt|}t||  t|t| ksTtd S )Nr   ri   r   r   )	r6   r5   r   setrq   r   r   r   rK   )r:   r   r   r   r   r   r   r    %test_reading_multiple_specific_sheetsw  s    
z1TestReaders.test_reading_multiple_specific_sheetsc                 C   s4   d}t j|| d d}dddg}t||  d S )Nblank_with_headerr   rS   rY   r   )r6   r5   rq   r   r   r   r   r   r    "test_reading_all_sheets_with_blank  s    
z.TestReaders.test_reading_all_sheets_with_blankc                 C   s$   t jd| dd}t|t  d S )NblankrS   r   )r6   r5   rq   rr   r	   )r:   r   r   r   r   r    test_read_excel_blank  s    z!TestReaders.test_read_excel_blankc                 C   s0   t ddgd}tjd| dd}t|| d S )NZcol_1Zcol_2rg   r  rS   r   r	   r6   r5   rq   rr   )r:   r   rO   r   r   r   r    !test_read_excel_blank_with_header  s    z-TestReaders.test_read_excel_blank_with_headerc                 C   s   |dkr|j tjjdd ttddgtddgdd	ggd
dgd}|dkrj|j tjjdd |d kr|dkr|j tjjdd td| }t	
|| d S )Nr   rb   rc   z
2016-03-12zMarc Johnsonz
2016-03-16z
Jack Blackg@xDzTimothy BrownZDateColWithBigIntZ	StringColrg   r   zMaybe not supported by openpyxl)r   r   z)Defaults to openpyxl, maybe not supportedZtestdateoverflow)rl   rm   r"   rn   ro   r	   r6   	Timestampr5   rq   rr   )r:   r+   r   r   rO   rN   r   r   r    test_date_conversion_overflow  s.    	z)TestReaders.test_date_conversion_overflowc                 C   sr   |dkr|j tjjdd d}d}tj|| |dd}tj|| d|d}tj||d	d
 tj||d	d
 d S Nr   rb   rc   rF   rS   r   r   )rW   rV   Frj   r{   )r:   r+   r   rs   filenamerV   rt   ru   r   r   r    test_sheet_name  s       zTestReaders.test_sheet_namec              	   C   sN   d| }t j|ddd}t|d"}t j|ddd}t|| W 5 Q R X d S )NrF   rS   r   r   rG   )r6   r5   rJ   rq   rr   )r:   r   pthrO   rM   r   r   r   r    test_excel_read_buffer  s
    z"TestReaders.test_excel_read_bufferc              	   C   s0   d}t jtdd tjd|d W 5 Q R X d S )NfoozUnknown engine: foorQ   r   r1   r\   )r:   r   Z
bad_enginer   r   r    test_bad_engine_raises  s    z"TestReaders.test_bad_engine_raisesrV   r   rS   c              	   C   s4   d}t jt|d tjd| |d W 5 Q R X d S Nz?Worksheet index 3 is invalid|Worksheet named 'Sheet4' not foundrQ   r  r   r\   )r:   r   rV   r`   r   r   r    test_bad_sheetname_raises  s    z%TestReaders.test_bad_sheetname_raisesc              	   C   s6   d| }d}t jt|d t| W 5 Q R X d S )Nr  uV   (No such file or directory|没有那个文件或目录|File o directory non esistente)rQ   )r"   r]   FileNotFoundErrorr6   r5   )r:   r   Zbad_filerR   r   r   r    test_missing_file_raises  s    
z$TestReaders.test_missing_file_raisesc              	   C   sd   d}|d krt }d}n&|dkr4ddlm} |}d}nt}d}tj||d t| W 5 Q R X d S )	Ns   foozLExcel file format cannot be determined, you must specify an engine manually.r   r   )	XLRDErrorzFUnsupported format, or corrupt file: Expected BOF record; found b'foo'zFile is not a zip filerQ   )r^   r   r  r   r"   r]   r6   r5   )r:   r   r   Z
bad_streamerrorr`   r  r   r   r    test_corrupt_bytes_raises  s    z%TestReaders.test_corrupt_bytes_raisesz^https://raw.githubusercontent.com/pandas-dev/pandas/main/pandas/tests/io/data/excel/test1.xlsx)urlZcheck_before_testc                 C   s0   d| }t |}t d| }t|| d S )NzYhttps://raw.githubusercontent.com/pandas-dev/pandas/main/pandas/tests/io/data/excel/test1rF   r   )r:   r   r  	url_tablelocal_tabler   r   r    test_read_from_http_url  s    

z#TestReaders.test_read_from_http_urlc              	   C   sf   t d| d}|djd| |d W 5 Q R X d| }tj||d}td| }t|| d S )NrF   rG   pandas-testKeyZBodys3://pandas-test/test1)Zstorage_options)rJ   Bucket
put_objectr6   r5   rq   rr   )r:   r   s3_resources3sorM   r  r  r  r   r   r    test_read_from_s3_url  s    "z!TestReaders.test_read_from_s3_urlc           	   	   C   s   t d| d}|djd| |d W 5 Q R X dd l}|jf |}| d| }t|}W 5 Q R X td| }t|| d S )NrF   rG   r  r  r   r!  )	rJ   r"  r#  s3fsZS3FileSystemr6   r5   rq   rr   )	r:   r   r$  r%  rM   r'  Zs3r  r  r   r   r    test_read_from_s3_object  s    "z$TestReaders.test_read_from_s3_objectc                 C   s   t j|dddd| }t|}ztd| }W n> tk
rt   dd l}d|  }t	
d|  Y nX t|| d S )	Nr2   r3   r4   rF   zfile://localhost/r    zfailing on )ospathjoinr6   r5   r   platformunamestripr"   r   rq   rr   )r:   r   r;   Z
localtabler  r  r-  Zplatform_infor   r   r    test_read_from_file_url-  s    
z#TestReaders.test_read_from_file_urlc                 C   sP   ddl m} d| }tj|ddd}|d| }tj|ddd}t|| d S )Nr   r   rF   rS   r   )pathlibr   r6   r5   rq   rr   )r:   r   r   str_pathrO   path_objr   r   r   r    test_read_from_pathlib_path?  s    z'TestReaders.test_read_from_pathlib_pathzpy.pathc                 C   s\   ddl m} tjd| }tj|ddd}| d| }tj|ddd}t|| d S )Nr   )localrF   rS   r   )	Zpy.pathr5  r*  r+  r,  r6   r5   rq   rr   )r:   r   Z	LocalPathr2  rO   r3  r   r   r   r    test_read_from_py_localpathL  s    z'TestReaders.test_read_from_py_localpathc              	   C   sD   t jd| }t|d }tj|ddd}~|  W 5 Q R X d S )NrF   rG   rS   r   r   )r*  r+  r,  rJ   r6   r5   read)r:   r   r2  rM   r   r   r   r    test_close_from_py_localpath[  s
    z(TestReaders.test_close_from_py_localpathc                 C   s   |dkr|j tjjdd tdtdddtddd	d
tddddtddddtddddtddddtddddtdddd tdd!dd"td#d$d%d&td'd(d)gi}tj	d*| d+d,}t
|| tj	d-| d+d,}t
|| d S ).Nr   rb   rc   ZTimerH   ri   rT   -   8   i r      1   i@       *   i    9   #   i 	   )      i           i'	 r   i`
 5   i 5    %   r   i       6   Z
times_1900rS   r   Z
times_1904)rl   rm   r"   rn   ro   r	   r   r   r6   r5   rq   rr   )r:   r+   r   r   rO   r   r   r   r    test_reader_secondsf  s4    

zTestReaders.test_reader_secondsc              	   C   sB  |dkr|j tjjdd tddgddgg}d| }td	d
t	ddgddt	ddgddt	ddgddt	ddgg|d}tj
|ddd	gdd}t|| ||_ddddg|_tj
|ddd	gd}tj||dd ||_tj
|d dd	gdd	gd!}tj||dd ddddg|_|d"d#g|_tj
|d$dd	gd}t|| ttd|_|d%d&g|_tj
|d'dd	gdd}t|| |jd	dgd	d(d%d&g|_tj
|d)ddd	gd!}t|| |d%d&g|_|d"d#g|_tj
|d*dd	gdd	gd!}t|| tj
|d+dd	gdd	gdd,}t|| d S )-Nr   rb   rc   r  barr   r   testmultiindexrH   r   
2015-01-01Tri   r   
2015-01-02FrT   r   
2015-01-03r   r   
2015-01-04rg   Z	mi_columnr   )rV   headerrW   r   r   Zmi_indexr   rj   ZbothrV   rW   rV  ilvl1ilvl2Zmi_index_namec1c2Zmi_column_name)levelZname_with_intZ	both_nameZboth_name_skiprows)rV   rW   rV  r[   )rl   rm   r"   rn   ro   r   from_productr	   r6   r
  r5   rq   rr   r   rh   Z	set_namesr   r   Z
set_levels)r:   r+   r   mimi_filerO   r   r   r   r    test_read_excel_multiindex  s    
               z&TestReaders.test_read_excel_multiindexzsheet_name,idx_lvl2Zboth_name_blank_after_mi_namer   r   Zboth_name_multiple_blanksc           	   	   C   s   |dkr|j tjjdd d| }tjddgddggd	d
gd}tddt	ddgddt	ddgddt	ddgddt	ddgg|tj
ddddg|fddgdd}tj||ddgddgd}t|| d S )Nr   z;Sheets containing datetimes not supported by pyxlsb (GH4679rc   rQ  r  rP  r   r   rZ  r[  r   rH   r   rR  Tri   r   rS  FrT   r   rT  r   r   rU  rX  rY  r   r   rW  )rl   rm   r"   rn   ro   r   r]  r	   r6   r
  Zfrom_arraysr5   rq   rr   )	r:   r+   r   rV   Zidx_lvl2r_  r^  rO   rN   r   r   r    +test_read_excel_multiindex_blank_after_name  s6    z7TestReaders.test_read_excel_multiindex_blank_after_namec                 C   sT   d| }t j|dddgd}tddg}tddd	d
ggd |d}t|| d S )NrQ  index_col_noner   rH   rV   rV  rw   re   keyvalri   rT   r   rg   )r6   r5   r   r]  r	   rq   rr   )r:   r   r_  rN   Zexp_columnsrO   r   r   r    &test_read_excel_multiindex_header_only  s
    z2TestReaders.test_read_excel_multiindex_header_onlyc           	      C   s  d| }t d d d d d gdddddgddd	d
dgdddddgdddddgdddddgg}dddddg}td d!d"d#d$d%gd&d'd(d)d*d+ggd,d-d.d/d0d1gd,d-d.d/d0d1ggd d gd2}td d!d"d#d$d%gd d3}t|||d4}tj|d5d,d6}t|| ||_	tj|d7d,d-gd6}t|| t dddddgddd	d
dgdddddgdddddgdddddgg}dddddg}td!d"d#d$d%gd'd(d)d*d+ggd,d-d.d/d0gd,d-d.d/d0ggd d gd2}td!d"d#d$d%gd d3}t|||d4}tj|d8d,d6}t|| ||_	tj|d9d,d-gd6}tj||d:d; d S )<NZtest_index_name_pre17ZR0C0ZR0C1ZR0C2ZR0C3ZR0C4ZR1C0ZR1C1ZR1C2ZR1C3ZR1C4ZR2C0ZR2C1ZR2C2ZR2C3ZR2C4ZR3C0ZR3C1ZR3C2ZR3C3ZR3C4ZR4C0ZR4C1ZR4C2ZR4C3ZR4C4ZC_l0_g0ZC_l0_g1ZC_l0_g2ZC_l0_g3ZC_l0_g4ZR0ZR_l0_g0ZR_l0_g1ZR_l0_g2ZR_l0_g3ZR_l0_g4ZR1ZR_l1_g0ZR_l1_g1ZR_l1_g2ZR_l1_g3ZR_l1_g4r   rH   ri   rT   r   r   r   r   r   rh   Zsingle_namesr   Zmulti_namesZsingle_no_namesZmulti_no_namesFrj   )
r   arrayr   r
   r	   r6   r5   rq   rr   r   )	r:   r   r  r3   rh   r^  sirO   r   r   r   r    test_excel_old_index_format  sf    
 	z'TestReaders.test_excel_old_index_formatc              
   C   s>   d}dD ]0}t jt|d tjd| |d W 5 Q R X qd S )Nz#Passing a bool to header is invalid)TFrQ   rF   )rV  r   )r:   r   r`   argr   r   r    test_read_excel_bool_header_argY  s    z+TestReaders.test_read_excel_bool_header_argc              	   C   sV  |dkr|j tjjdd tjd| dddgd}td	d
tddgddtddgddtddgddtddggddddgd}t	
|| tjd| dtddgd}t	
|| tjd| ddd d}t	
|| tjd| ddddddgd}tddtddgddtddgddtddggddddgd}t	
|| d S )Nr   rb   rc   ZtestskiprowsZskiprows_listr   ri   )rV   r[   rH   r   rR  Tr   rS  FrT   r   rT  r   r   rU  r   r   r   r   rg   c                 S   s   | dkS )N)r   ri   r   r   r   r   r    r     r   z6TestReaders.test_read_excel_skiprows.<locals>.<lambda>)rV   r[   r   )rl   rm   r"   rn   ro   r6   r5   r	   r
  rq   rr   r   rl  )r:   r+   r   r   rO   r   r   r    test_read_excel_skiprows`  s\      
	

	z$TestReaders.test_read_excel_skiprowsc                 C   s@   d}t jd| |d}t d| }|d | }t|| d S )Nr   rF   Znrowsr   )r:   r   num_rows_to_pullr   rO   r   r   r    test_read_excel_nrows  s
    z!TestReaders.test_read_excel_nrowsc                 C   s@   t d| }t|}|d }t jd| |d}t|| d S )NrF   r   rr  )r6   r5   r   rq   rr   )r:   r   rO   Znum_records_in_filers  r   r   r   r    0test_read_excel_nrows_greater_than_nrows_in_file  s
    z<TestReaders.test_read_excel_nrows_greater_than_nrows_in_filec              	   C   s4   d}t jt|d tjd| dd W 5 Q R X d S )Nz'nrows' must be an integer >=0rQ   rF   r   rr  r\   r_   r   r   r    +test_read_excel_nrows_non_integer_parameter  s    z7TestReaders.test_read_excel_nrows_non_integer_parameterc              	   C   s   d| }t jtdd tj|dddd}tdd	d
gd
ddgdd}d|j_t || tj|ddd}t	d
ddgdd	d
gd}t 
|| tj|ddd}tddd	gdd}t || W 5 Q R X d S )NZtest_squeezezThe squeeze argument has been deprecated and will be removed in a future version. Append .squeeze\("columns"\) to the call to squeeze.

rQ   Ztwo_columnsr   T)rV   rW   squeezeri   rT   r   r   r=  r   rj  r   )rV   rw  )r   r   Z
one_columnrH   )rq   r   r   r6   r5   r   r   r   Zassert_series_equalr	   rr   )r:   r   rM   r   rO   r   r   r    test_read_excel_squeeze  s(       z#TestReaders.test_read_excel_squeezec              	   C   s>   t jtdd td| dd W 5 Q R X td|  d S )NF)r   rF   rS   r   )rq   r   r   r6   r5   r:   r   r   r   r    test_deprecated_kwargs  s    z"TestReaders.test_deprecated_kwargsc                 C   s^   d| }ddddg}t jddddgdd}t||d	d
}tj|dddgd d}t|| d S )NrQ  )re   re   rf  )rT   r   )rw   rw   )rH   ri   )r   rH   ra  )ri   rT   rk  rc  r   rH   rW  )r   from_tuplesr	   r6   r5   rq   rr   )r:   r   	file_namer3   idxrO   rN   r   r   r    "test_no_header_with_list_index_col  s    
    z.TestReaders.test_no_header_with_list_index_colc                 C   s>   d| }dt jddg}t|dgd}t|}t|| d S )NZone_col_blank_lineg      ?rH   ri   numbersrg   )r   r   r	   r6   r5   rq   rr   )r:   r   r|  r3   rO   rN   r   r   r    test_one_col_noskip_blank_line  s
    
z*TestReaders.test_one_col_noskip_blank_linec                 C   sj   d| }t ddg}tjtjgtjtjgddgddgg}t||d}tj|d	d
dgd}t|| d S )NrQ  )r   rw   )r   re   rH   rT   ri   r   rg   Zmi_column_empty_rowsr   rd  )	r   r{  r   r   r	   r6   r5   rq   rr   )r:   r   r|  rh   r3   rO   rN   r   r   r     test_multiheader_two_blank_lines  s    $  z,TestReaders.test_multiheader_two_blank_linesc                 C   s$   d| }t |}|jdks tdS )z
        Sheets can contain blank cells with no data. Some of our readers
        were including those cells, creating many empty rows and columns
        Ztrailing_blanks)rT   rT   N)r6   r5   shaperK   )r:   r   r|  rN   r   r   r    test_trailing_blanks  s    
z TestReaders.test_trailing_blanksc              	   C   s`   |dkrt d |dkr0|jt jjdd t jtdd tj	d| d	d
 W 5 Q R X d S )Nr   *chartsheets do not exist in the ODF formatr   4pyxlsb can't distinguish chartsheets from worksheetsrc   z"Worksheet named 'Chart1' not foundrQ   
chartsheetZChart1r   
r"   r   rl   rm   rn   ro   r]   r^   r6   r5   r:   r+   r   r   r   r   r    test_ignore_chartsheets_by_str  s    
z*TestReaders.test_ignore_chartsheets_by_strc              	   C   s`   |dkrt d |dkr0|jt jjdd t jtdd tj	d| d	d
 W 5 Q R X d S )Nr   r  r   r  rc   z0Worksheet index 1 is invalid, 1 worksheets foundrQ   r  rH   r   r  r  r   r   r    test_ignore_chartsheets_by_int  s    
 z*TestReaders.test_ignore_chartsheets_by_intc              	   C   sf   t jd| ddd}tdddddd	gd
dddddgddddddggddddddgd}t|| d S )NZtest_decimal,rH   )decimalr[   gAc̝ė@g	hAABCZpoig2[j@ri   gHzG^@g{G@ZDEFZuytgUq&?rT   g%Cq@g^@ZGHIZrezg)@ZIdZNumber1ZNumber2ZText1ZText2ZNumber3rg   r   )r:   r+   r   rN   rO   r   r   r    test_euro_decimal_format  s    z$TestReaders.test_euro_decimal_format)S__name__
__module____qualname__r"   fixturer>   rP   ra   rv   rz   rn   parametrizer|   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	  r  r  r  r  r  r  r  networkrq   r  tdZskip_if_not_us_localeZ
single_cpur&  r(  Zslowr0  r4  
skip_if_noZcheck_file_leaksr6  r8  rO  r`  rb  ri  rn  rp  rq  rt  ru  rv  rx  rz  r~  r  r  r  r  r  r  r   r   r   r    r/   w   s   

5 2


		R







 
	



!V
"H7	r/   c                
   @   s  e Zd Zejdddd Zdd Zdd Zej	d	d
ddgdd Z
dd Zdd Zej	ddddgddgdddgddggdd Zdd Zdd Zdd Zdd  Zd!d" Zejjed
k	oeed#kd$d%d&d' Zej	d(d)d*gd+d, Zd-d. Zd/d0 Zd1d2 Zd3d4 Zd
S )5TestExcelFileReadTr0   c                 C   s2   t tj|d}||ddd |td| dS )zH
        Change directory and set engine for ExcelFile objects.
        r1   r2   r3   r4   rI   N)r   r6   rI   r7   r8   r9   r   r   r    r>      s    z#TestExcelFileRead.cd_and_set_enginec              	   C   s^   dddddd}t d| }|j}W 5 Q R X |d k	r>|}n||dd   }||ksZtd S )Nr   r   r   r   rC   rF   rH   )r6   rI   r   rK   )r:   r   r   r<   rL   r4   rN   rO   r   r   r    rP   )  s    z"TestExcelFileRead.test_engine_usedc              	   C   s  t d| }t j|dddgd}W 5 Q R X tdgdgdgtjgdggd	gd
}t|| t d| }t j|dddgd}W 5 Q R X ttjgdgtjgtjgdggd	gd
}t|| t d| }t j|dddgd}W 5 Q R X tdgdgdgtjgdggd	gd
}t|| t d| }t j|dddgd}W 5 Q R X ttjgdgtjgtjgdggd	gd
}t|| d S )NZtest4rS   FapplerV   Zkeep_default_naZ	na_valuesZNArH   rabbitr   rg   Ttest51.#QNANr   )r6   rI   r5   r	   r   r   rq   rr   )r:   r   r4   r   rO   r   r   r    test_excel_passes_na;  s`                    z&TestExcelFileRead.test_excel_passes_na	na_filterNFc              	   C   s   i }|d k	r||d< t d| "}t j|fdddgd|}W 5 Q R X |dkrldgd	gd
gdgdgg}ntjgd	gtjgtjgdgg}t|dgd}t|| d S )Nr  r  rS   Tr  r  Fr  rH   r   r  r   rg   )r6   rI   r5   r   r   r	   rq   rr   )r:   r   r  r@   r4   r   rO   r   r   r    test_excel_passes_na_filtera  s$    z-TestExcelFileRead.test_excel_passes_na_filterc              	   C   s\  |dkr|j tjjdd td| *}tj|ddd}tj|ddgdd}W 5 Q R X tj	||d	d
 tj	||d	d
 td| &}|j
ddd}|j
ddgdd}W 5 Q R X tj	||d	d
 tj	||d	d
 td| }tj|dddd}W 5 Q R X t	||jd d  td| }|j
dddd}W 5 Q R X t	||jd d  d S )Nr   rb   rc   rF   r   r   rH   r   Frj   )rW   )r[   rW   r   r   )rW   r   )rl   rm   r"   rn   ro   r6   rI   r5   rq   rr   rB   r   )r:   r+   r   rs   r4   rt   ru   ry   r   r   r    test_excel_table_sheet_by_indexz  s,    z1TestExcelFileRead.test_excel_table_sheet_by_indexc           	   	   C   s   |dkr|j tjjdd d}d}t|| }|j|dd}W 5 Q R X t|| }|jd|d}W 5 Q R X tj	||d	d
 tj	||d	d
 d S r  )
rl   rm   r"   rn   ro   r6   rI   rB   rq   rr   )	r:   r+   r   rs   r  rV   r4   Z	df1_parseZ	df2_parser   r   r    r    s    z!TestExcelFileRead.test_sheet_namerV   rT   r   r   rS   c              
   C   sH   d}t jt|d, td| }|j|d W 5 Q R X W 5 Q R X d S r  )r"   r]   r^   r6   rI   rB   )r:   r   rV   r`   r4   r   r   r    r    s    z+TestExcelFileRead.test_bad_sheetname_raisesc              
   C   sf   d| }t j|dd|d}t|d,}t |}t j|ddd}W 5 Q R X W 5 Q R X t|| d S )NrF   rS   r   rV   rW   r   rG   r   )r6   r5   rJ   rI   rq   rr   )r:   r   r   r  rO   rM   rE   r   r   r   r    r    s    $z(TestExcelFileRead.test_excel_read_bufferc              
   C   sP   t d| d.}t|}tj|dd|d W 5 Q R X W 5 Q R X |jsLtd S )NrF   rG   rS   r   r  )rJ   r6   rI   r5   closedrK   )r:   r   r   rM   rD   r   r   r    test_reader_closes_file  s    &z)TestExcelFileRead.test_reader_closes_filec              
   C   sJ   d}t d| .}tjt|d t j|dd W 5 Q R X W 5 Q R X d S )Nz8Engine should not be specified when passing an ExcelFilerF   rQ   r  r1   )r6   rI   r"   r]   r^   r5   )r:   r   r`   Zxlr   r   r    test_conflicting_excel_engines  s    z0TestExcelFileRead.test_conflicting_excel_enginesc              	   C   sR   t jd| |d}td| d}| }W 5 Q R X t j||d}t|| d S )NrF   r1   rG   )r6   r5   rJ   r7  rq   rr   )r:   r   r   rO   rM   r3   r   r   r   r    test_excel_read_binary  s
    z(TestExcelFileRead.test_excel_read_binaryc              	   C   sF   t d| d}t|}W 5 Q R X tjd| |d}t|| d S )NrF   rG   r1   )rJ   r6   r5   rq   rr   )r:   r   r   rM   rN   rO   r   r   r    %test_excel_read_binary_via_read_excel  s    z7TestExcelFileRead.test_excel_read_binary_via_read_excelr   zxlrd no longer supports xlsxrc   c                 C   s.   t dgdgd}tjddd}t|| d S )Nu   ZColumn1rg   zhigh_surrogate.xlsxr   r1   r  )r:   rO   r   r   r   r    test_excel_high_surrogate  s    z+TestExcelFileRead.test_excel_high_surrogater  zdf_empty.xlsxzdf_equals.xlsxc                 C   s`   t dgdd}tjddgddgd}td	d
gg||dd}tj|dddd	gd}t|| d S )NZZI2rj  re  )rw   zB.1ZI11ZI12ra  rH   rT   r   )r   rh   r   rS   r   rW  )r
   r   r{  r	   r6   r5   rq   rr   )r:   r  r}  colsrO   rN   r   r   r    test_header_with_index_col  s       z,TestExcelFileRead.test_header_with_index_colc           	   	   C   s   |dkr|j tjjdd d| }t|}tj|ddgd|d}W 5 Q R X tj	t
dt
d	fgt
d t
d	 gd
}tg |d}t|| d S )Nr   rb   rc   Ztest_datetime_mir   rH   )rV  rW   r   z
02/29/2020z
03/01/2020ra  rg   )rl   rm   r"   rn   ro   r6   rI   r5   r   r{  to_datetimeZto_pydatetimer	   rq   rr   )	r:   r+   r   r   rM   r4   r   Zexpected_column_indexrO   r   r   r    test_read_datetime_multiindex  s"     z/TestExcelFileRead.test_read_datetime_multiindexc              
   C   s>   t jtdd& td| dd W 5 Q R X W 5 Q R X d S )NzValue must be one of *rQ   zio.excelz.readerabc)r"   r]   r^   r6   Zoption_contextry  r   r   r    test_engine_invalid_option  s    z,TestExcelFileRead.test_engine_invalid_optionc              	   C   s^   |dkrt d |dkr0|jt jjdd td| }|jdgksPt	W 5 Q R X d S )Nr   r  r   r  rc   r  rS   )
r"   r   rl   rm   rn   ro   r6   rI   Zsheet_namesrK   )r:   r+   r   r   r4   r   r   r    test_ignore_chartsheets  s    
z)TestExcelFileRead.test_ignore_chartsheetsc              
   C   s   t f}|d krt  n|dkr4dd l}t |jjf}td| R}t|	d t
d. ztj||d W n |k
r   Y nX W 5 Q R X W 5 Q R X d S )Nr   r   ZcorruptFr1   )r   r"   r   r   Zbiffhr  rq   Zensure_cleanr   
write_textr   r6   rI   )r:   r   r   errorsr   filer   r   r    test_corrupt_files_closed"  s    
z+TestExcelFileRead.test_corrupt_files_closed)r  r  r  r"   r  r>   rP   r  rn   r  r  r  r  r  r  r  r  r  r  Zskipifr   r   r  r  r  r  r  r  r   r   r   r    r    s:   

&






r  )/r   r   	functoolsr   r*  r1  r   urllib.errorr   zipfiler   numpyr   r"   Zpandas.util._test_decoratorsutilZ_test_decoratorsr  Zpandasr6   r	   r
   r   r   Zpandas._testingZ_testingrq   Zpandas.tests.io.excelr   Zpandas.util.versionr   r&   r#   r  rn   filterwarningsZengine_paramsr   boolr!   r%   r  r,   r   r   r/   r  r   r   r   r    <module>   sp   




         1