o
    $j:                  
   @  s  d dl mZ d dlmZmZ d dlmZ d dlmZ d dlZd dl	m
Z
 d dlZd dlZd dlmZ d dlmZ d dlZd dlZd d	lmZ d dlm  mZ d dlZd d
lmZmZmZmZm Z  d dl!m"Z# e rnej$j%Z&g dZ'ej(de)dgdej(de)dgdej(de)dgdej(de)ddej(de)ddej(de)ddgZ*d3ddZ+dd Z,ej-dd e*D e.ddd Z/ej-d d! Z0ej-d"d Z1ej-d#d$ Z2d4d&d'Z3d5d+d,Z4d-d. Z5G d/d0 d0Z6G d1d2 d2Z7dS )6    )annotations)datetimetime)partial)BytesION)Path)URLError)
BadZipFile)is_platform_windows)	DataFrameIndex
MultiIndexSeriesread_csv).xls.xlsx.xlsm.xlsb.odsxlrdmarksopenpyxlpyxlsbodfcalaminepython_calamineread_extstrreturnboolc                 C  s   | j d } | dkr|dkrdS | dkr|dkrdS |dkr#| dvr#dS | dkr-|d	kr-dS |d	kr7| d
vr7dS | dkrA|dkrAd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   r   >   r   r   r   T)values)enginer    r#   c/var/www/html/Deteccion_Ine/venv/lib/python3.10/site-packages/pandas/tests/io/excel/test_readers.py_is_valid_engine_ext_pair@   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_marksU   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-   )paramsZidsc                 C     | j S )zS
    Fixture for Excel reader engine and read_ext, only including valid pairs.
    )r'   )requestr#   r#   r$   engine_and_read_ext_   s   r1   c                 C  s   | \}}|S Nr#   r1   r"   r   r#   r#   r$   r"   o      r"   c                 C  s   | \}}|S r2   r#   r3   r#   r#   r$   r   u   r4   c                 C  s"   | dddd}t |dddd}|S )	zI
    Obtain the reference data from read_csv with the Python engine.
    iodatacsvz	test1.csvr   Tpython)	index_colZparse_datesr"   )r   )datapathfilepathdf_refr#   r#   r$   r<   {   s   r<   
str | Nonec                 C  s   dS )Nnsr#   )r   r"   r#   r#   r$   get_exp_unit   s   r?   expectedr   Nonec                 C  s$   d | j _t||}| j || _ d S r2   )indexnamer?   Zas_unit)r@   r   r"   unitr#   r#   r$   adjust_expected   s   
rE   c                 C  s$   | dkr| tjjdd d S d S )Nr   z3Sheets containing datetimes not supported by pyxlsbreason)applymarkerr&   markxfail)r"   r0   r#   r#   r$   xfail_datetimes_with_pyxlsb   s   rK   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	dd Z
ejdg dg dg dg dg dg d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d&d' Zejd(d)d*gd+d, Zd-d. Zd/d0 Zd1d2 Zd3d4 Zd5d6 Zd7d8 Zd9d: Zd;d< Zejd=d)eg d>g d?g d>d@dAej dBgdCfdDdEe!e!dCee"g d>dDdFe"g d?dEdFe"g dGdHdFe"dIdJej dKgdHdFdCfgdLdM Z#dNdO Z$dPdQ Z%dRdS Z&ejdTi dUfdVdWidUfgdXdY Z'dZd[ Z(ejd\d]ed^d_gifd`edagdbfgdcdd Z)dedf Z*dgdh Z+didj Z,dkdl Z-dmdn Z.dodp Z/ej0dqdrds Z1dtdu Z2dvdw Z3dxdy Z4ejdzd{d|d{gd{d|gd}d~d}gd}d~ggdd Z5dd Z6dd Z7ejj8ejj9dd Z:e;j<ejj9dd Z=ejj9dd Z>ejj?dd Z@dd ZAe;Bddd ZCdd ZDdd ZEdd ZFejddej dddgfdej gd fgdd ZGdd ZHdd ZIdd ZJdd ZKdd ZLdd ZMdd ZNdd ZOejdddd|dUgd|d)fddd)d|dUgd)fddd|dUgd|dUgd)fddd|dUgd|d)fddd)d)d|d*gfddd)d)dd fgdd ZPdd ZQdd ZRdd ZSddÄ ZTddń ZUddǄ ZVddɄ ZWdd˄ ZXd)S )TestReadersTZautousec                 C  2   t tj|d}||ddd |td| dS )zG
        Change directory and set engine for read_excel calls.
        r"   r5   r6   excel
read_excelN)r   pdrQ   chdirsetattrselfr"   r:   monkeypatchfuncr#   r#   r$   cd_and_set_engine      zTestReaders.cd_and_set_enginec           	      C  s   dd }| tjd| dddddd}td	| d
}t|}W d    n1 s+w   Y  |d ur7|}n||dd   }||ksEJ d S )Nc                 _  r/   r2   rO   )rV   argskwargsr#   r#   r$   parser   s   z,TestReaders.test_engine_used.<locals>.parserparser   r   r   r   xlsxZxlsmZxlsbxlsZodstest1rb   )rT   rR   	ExcelFileopenrQ   )	rV   r   r"   rW   r]   expected_defaultsfresultr@   r#   r#   r$   test_engine_used   s   zTestReaders.test_engine_usedc              	   C  s   ddiddiddiddiddid}|dv rt d}n|d	kr&t d
}nt d}|d urZtjt|d tjd| dd||dd   d W d    d S 1 sSw   Y  d S d S )Nfooabcd{   TrueTr_   >   r   r   z8open_workbook() got an unexpected keyword argument 'foo'r   z/load() got an unexpected keyword argument 'foo'z8load_workbook() got an unexpected keyword argument 'foo'matchrb   Sheet1r   rd   )
sheet_namer9   Zengine_kwargs)reescaper&   raises	TypeErrorrR   rQ   )rV   r   r"   rg   msgr#   r#   r$   test_engine_kwargs   s*   
"zTestReaders.test_engine_kwargsc                 C  s   d}t jt|d tjd| dddd W d    n1 sw   Y  t jt|d tjd| dd	gddd
 W d    d S 1 sDw   Y  d S )Nz Passing an integer for `usecols`ro   rb   rq   r      rr   r9   usecolsSheet2rd   rr   skiprowsr9   r{   r&   ru   
ValueErrorrR   rQ   rV   r   rw   r#   r#   r$   test_usecols_int   s   "zTestReaders.test_usecols_intc                 C  sv   t || |ddg }t||| tjd| ddg dd}tjd| dd	gdg dd
}t|| t|| d S )NBCrb   rq   r   )r      ry   rz   r|   rd   r}   rK   rE   rR   rQ   tmassert_frame_equal)rV   r0   r"   r   r<   r@   df1df2r#   r#   r$   test_usecols_list   s   
	zTestReaders.test_usecols_listc                 C  s  t || |g d }t||| tjd| dddd}tjd| ddgddd	}t|| t|| |d
dg }t||| tjd| dddd}tjd| ddgddd	}t|| t|| tjd| dddd}tjd| ddgddd	}t|| t|| d S )NAr   r   rb   rq   r   zA:Drz   r|   rd   r}   r   r   zA,C,DzA,C:Dr   )rV   r0   r"   r   r<   r@   r   df3r#   r#   r$   test_usecols_str   sR   
	zTestReaders.test_usecols_strr{   )r   rd   ry   )r   ry   rd   )rd   r   ry   )rd   ry   r   )ry   r   rd   )ry   rd   r   c                 C  sH   t || |ddg }t||| tjd| dd|d}t|| d S )Nr   r   rb   rq   r   rz   r   )rV   r0   r"   r   r{   r<   r@   ri   r#   r#   r$   .test_usecols_diff_positional_int_columns_order/  s   
z:TestReaders.test_usecols_diff_positional_int_columns_orderr   Dc                 C  s>   |ddg }t t||_tjd| d|d}t|| d S )Nr   r   rb   rq   rr   r{   )rangelenrB   rR   rQ   r   r   )rV   r   r{   r<   r@   ri   r#   r#   r$   .test_usecols_diff_positional_str_columns_order?  s   z:TestReaders.test_usecols_diff_positional_str_columns_orderc                 C  s>   t || |}t||| tjd| ddd}t|| d S Nrb   rq   r   rr   r9   r   rV   r0   r"   r   r<   r@   ri   r#   r#   r$   test_read_excel_without_slicingG  s
   
z+TestReaders.test_read_excel_without_slicingc                 C  sH   t || |ddg }t||| tjd| dddd}t|| d S )Nr   r   rb   rq   r   zA,D:Erz   r   r   r#   r#   r$   test_usecols_excel_range_strP  s   
z(TestReaders.test_usecols_excel_range_strc                 C  sL   d}t jt|d tjd| ddd W d    d S 1 sw   Y  d S )NzInvalid column name: E1ro   rb   rq   zD:E1r   r   r   r#   r#   r$   $test_usecols_excel_range_str_invalid[  s   "z0TestReaders.test_usecols_excel_range_str_invalidc                 C  sT   d}t jt|d tjd| ddgddgd W d    d S 1 s#w   Y  d S )Nz(list indices must be integers.*, not strro   rb   rq   r   r   rz   r&   ru   rv   rR   rQ   r   r#   r#   r$   test_index_col_label_errora  s   "z&TestReaders.test_index_col_label_errorc                 C  s<   t jd| ddd}tg dtg ddd}t|| d S )Nrb   Sheet3r   r   )r   r   r   EFrC   columnsrB   )rR   rQ   r   r   r   r   rV   r   ri   r@   r#   r#   r$   test_index_col_strl  s
   zTestReaders.test_index_col_strc                 C  sR   t jd| dg dd}tg dtg gd g gd g ddd}t|| d S )	Nrb   r   r   r   )r   r   r   ry   Zlevelscodesnamesr   )rR   rQ   r   r   r   r   r   r#   r#   r$   test_index_col_emptyt  s   z TestReaders.test_index_col_emptyr9   Nr   c                 C  sT   t jd| d|d}tg dg dgg dd}|r"||j| }t|| d S )Nrb   Sheet4r   )i1ax)i2by)z
Unnamed: 0Zcol1Zcol2r   )rR   rQ   r   	set_indexr   r   r   )rV   r   r9   ri   r@   r#   r#   r$   test_index_col_with_unnamed  s   
z'TestReaders.test_index_col_with_unnamedc                 C  sL   d}t jt|d tjd| dgd W d    d S 1 sw   Y  d S )NzEUsecols do not match columns, columns expected but not found: \['E'\]ro   rb   r   r{   r   r   r#   r#   r$   %test_usecols_pass_non_existent_column  s
   "z1TestReaders.test_usecols_pass_non_existent_columnc                 C  sN   d}t jt|d tjd| ddgd W d    d S 1 s w   Y  d S )Nz['usecols' must either be list-like of all strings, all unicode, all integers or a callable.ro   rb   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test2rq   rr   ZaaaaZbbbbbTestZTest1r   rR   rQ   r   r   r   )rV   r   parsedr@   r#   r#   r$   test_excel_stop_iterator  s   z$TestReaders.test_excel_stop_iteratorc                 C  sd   t || |dkr|dkr|tjjdd tjd| dd}ttj	ggdgd	}t
|| d S )
Nr   r   z+Calamine can't extract error from ods filesrF   Ztest3rq   r   r   r   )rK   rH   r&   rI   rJ   rR   rQ   r   npnanr   r   )rV   r0   r"   r   r   r@   r#   r#   r$   test_excel_cell_error_na  s   
z$TestReaders.test_excel_cell_error_nac           	      C  s   t || |}t||| tjd| ddd}tjd| ddgdd}t|| t|| tjd| dddd}t||jd d	  d S )
Nrb   rq   r   r   r|   rd   rr   r~   r9   rr   r9   
skipfooter)rK   rE   rR   rQ   r   r   iloc)	rV   r0   r"   r   r<   r@   r   r   r   r#   r#   r$   test_excel_table  s   
zTestReaders.test_excel_tablec                 C  sV  t || t||}tg dg dg dg dg dttdddtddd	td
ddtdddtdddgd| ddd}d}tj|| dd}t	|| |
 }d|j|jd df< tj|| dd}t	|| t|jD ]\}	}
tj|| d|	d}||
}t	|| qt|d t|d< tj|| ddtid}t	|| d S )N)rd   r      r   )g      ?g      @gHzG?gQ?g&.>)TFTTF)rd   r   ry   r      )r   ry   cdei  
         iq  rd         i  ry   M8[]dtype)IntColFloatColBoolColStrColStr2ColZDateColZ
test_typesrq   r   g      @r   r   r   rr   
converters)rK   r?   r   	from_dictr   r   rR   rQ   r   r   copylocrB   	enumerater   r   applyr   )rV   r0   r"   r   rD   r@   basenameactualZfloat_expectedZicolrC   expr#   r#   r$   test_reader_special_dtypes  sJ   









z&TestReaders.test_reader_special_dtypesc              
   C  sz   d}t g ddtjdddgg d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_converters)rd   r   r   r   g      )@gL2@g3333333@g:0y5>)Foundr   r   	Not foundr   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>  s    z4TestReaders.test_reader_converters.<locals>.<lambda>c                 S  s   | rd|  S t jS )Nr   )r   r   r   r#   r#   r$   r     s    c                 S  s   | dkrdS dS )Nr   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   r   ry   rq   r   )r   r   r   r   rR   rQ   r   r   )rV   r   r   r@   r   r   r#   r#   r$   test_reader_converters  s"   
	
z"TestReaders.test_reader_convertersc                 C  s   d}t || }tg dg dg dddtjdgd}t|| t j|| dd	td
d}|d d|d< |d d	|d< t	g ddd|d< t|| d}t
jt|d t j|| ddid W d    d S 1 srw   Y  d S )N	testdtyperd   r   ry   r         @      @      @      @      ?       @      @r   r   r   r   float64float32)r   r   r   r   r   r   Z001Z002Z003Z004r   r   z(Unable to convert column d to type int64ro   r   int64)rR   rQ   r   r   r   r   r   r   astyper   r&   ru   r   )rV   r   r   r   r@   rw   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   2r   c                 C  s&   d}t j|| |d}t|| d S )Nr   r   rR   rQ   r   r   )rV   r   r   r@   r   r   r#   r#   r$   test_reader_dtype_str.  s   z!TestReaders.test_reader_dtype_strc                   s  |dv rt d| d ttddgddtdd	gd
dtddgddtddgddttjdgddttjdgd
dttjdgddttjdgddttdgd ttjtjgddd
t|}j	|ddd tj
|d|d}W d    n1 sw   Y  |dkrdd lddlm  t fddjD } |d jjjdd |d<  d d g|d!< n}t||}|d d"| d#|d< t|| d S )$Nr   r   No engine for filetype: ''rd   ry   ZInt64r   r   r   ZFloat64TFbooleanr   r   string   g      @z
2019-12-31r   )
r   r   r   r   r   rh   ghijtestrr   rB   rr   dtype_backendpyarrowr   )ArrowExtensionArrayc                   s$   i | ]}| j | d dqS )T)Zfrom_pandas)array)r+   colr  dfpar#   r$   
<dictcomp>n  s    z2TestReaders.test_dtype_backend.<locals>.<dictcomp>r  us)rD   r  r   r   )r&   skipr   r   rR   NA	Timestampr   ensure_cleanto_excelrQ   r  Zpandas.arraysr  r   r  Z	_pa_arraycast	timestampr?   r   r   )rV   r   r  r"   	file_pathri   r@   rD   r#   r  r$   test_dtype_backendP  sJ   
zTestReaders.test_dtype_backendc                 C  s   |dv rt d| d ttjdgdtjgd}t|}|j|ddd	 tj	|dd
dd}W d    n1 s;w   Y  t
|| d S )Nr  r  r  r   r   r   r   r  Fr  numpy_nullabler   )rr   r  r   )r&   r  r   r   r   r   r  r   rR   rQ   r   )rV   r   r  r#  ri   r#   r#   r$   test_dtype_backend_and_dtype  s   z(TestReaders.test_dtype_backend_and_dtypec              	   C  s  |dv rt d| d td|g ttjddgtjdtjdtjgtjdd	}t	
|}|j|d
dd tj|d
dd}W d    n1 sLw   Y  ttddgt|dtdd gt|dd	}t	j||dd W d    d S 1 s}w   Y  d S )Nr  r  r  zmode.string_storager   r   r   r   r%  r  Fr  r&  r  )Zcheck_column_type)r&   r  rR   option_contextr   r   r  Zobject_r  r   r  r   rQ   r   ZStringDtyper   )rV   r   Zstring_storager  r#  ri   r@   r#   r#   r$   test_dtype_backend_string  s*   "z%TestReaders.test_dtype_backend_stringzdtypes, exp_valuerd   a.1r   c           	      C  st   d}dt i|}| }tj|| |d}ttdgt dt|g|s#t nd dd}||ks2J dt|| d S )NZdf_mangle_dup_col_dtypesr   r   rd   )r   r*  zdtype dict changed)objectr   rR   rQ   r   r   r   r   )	rV   r   ZdtypesZ	exp_valuer   Z
dtype_dictZdtype_dict_copyri   r@   r#   r#   r$   test_dtype_mangle_dup_cols  s   z&TestReaders.test_dtype_mangle_dup_colsc                 C  s2   d}t || }tdg di}t|| d S )NZtest_spacesZtestcol)zthis is greatz4    spacesz1 trailing z
 1 leadingz2  spaces  multiple  timesr   )rV   r   r   r   r@   r#   r#   r$   test_reader_spaces  s   zTestReaders.test_reader_spaceszbasename,expectedzgh-35802ZCOLUMNzTest (1)zgh-36122z
got 2nd sar   c                 C  s6   |dkrt d|  t|| }t|| d S )Nr   zSkipped for engine: )r&   r  rR   rQ   r   r   )rV   r"   r   r   r@   r   r#   r#   r$   test_read_excel_ods_nested_xml  s   	z*TestReaders.test_read_excel_ods_nested_xmlc                 C  sF   d}t j|| d d}g d}t||  |t| ks!J d S )Ntest_multisheetr   )CharlieAlphaBeta)rR   rQ   r   assert_contains_allkeyslistrV   r   r   dfsexpected_keysr#   r#   r$   test_reading_all_sheets  s
   z#TestReaders.test_reading_all_sheetsc                 C  sV   d}g d}t j|| |d}tt|}t||  t|t| ks)J d S )Nr/  )r   r0  r0  r   )rR   rQ   r5  setr   r3  r4  r   )rV   r   r   r8  r7  r#   r#   r$   %test_reading_multiple_specific_sheets  s   z1TestReaders.test_reading_multiple_specific_sheetsc                 C  s2   d}t j|| d d}g d}t||  d S )Nblank_with_headerr   )rq   r|   r   )rR   rQ   r   r3  r4  r6  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blankrq   r   )rR   rQ   r   r   r   )rV   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_2r   r<  rq   r   )r   rR   rQ   r   r   )rV   r   r@   r   r#   r#   r$   !test_read_excel_blank_with_header	  s   z-TestReaders.test_read_excel_blank_with_headerc                 C  s   t jtdd tjd| dgd d W d    n1 sw   Y  t jtdd tjd| dd d d	 W d    d S 1 sAw   Y  d S )
Nz \(sheet: Sheet1\)$ro   r<  rd   )headerrr   rb   c                 S  s   dd S )Nrd   r   r#   r   r#   r#   r$   r         zHTestReaders.test_exception_message_includes_sheet_name.<locals>.<lambda>)r{   rr   )r&   ru   r   rR   rQ   ZeroDivisionErrorrV   r   r#   r#   r$   *test_exception_message_includes_sheet_name  s   "z6TestReaders.test_exception_message_includes_sheet_namez-ignore:Cell A4 is marked:UserWarning:openpyxlc                 C  s   t || ttddgtddgddggddgd	}|d
kr*|tjjdd |d u r<|dv r<|tjjdd td| }t	
|| d S )Nz
2016-03-12zMarc Johnsonz
2016-03-16z
Jack Blackg@xDzTimothy BrownZDateColWithBigIntZ	StringColr   r   zMaybe not supported by openpyxlrF   )r   r   z)Defaults to openpyxl, maybe not supportedZtestdateoverflow)rK   r   rR   r  rH   r&   rI   rJ   rQ   r   r   )rV   r0   r"   r   r@   ri   r#   r#   r$   test_date_conversion_overflow  s$   
	z)TestReaders.test_date_conversion_overflowc           
      C  sf   t || d}d}|}t||| tj|| |dd}tj|| d|d}	t|| t|	| d S Nrb   rq   r   r   )r9   rr   r   )
rV   r0   r   r"   r<   filenamerr   r@   r   r   r#   r#   r$   test_sheet_name1  s   

zTestReaders.test_sheet_namec                 C  sd   d| }t j|ddd}t|d}t j|ddd}t|| W d    d S 1 s+w   Y  d S )Nrb   rq   r   r   rc   )rR   rQ   rf   r   r   )rV   r   pthr@   rh   r   r#   r#   r$   test_excel_read_bufferB  s   "z"TestReaders.test_excel_read_bufferc                 C  sF   d}t jtdd tjd|d W d    d S 1 sw   Y  d S )Nrk   zUnknown engine: fooro   r   rO   r   )rV   Z
bad_enginer#   r#   r$   test_bad_engine_raisesI  s   "z"TestReaders.test_bad_engine_raisesrr   ry   r   r   rq   c                 C  sJ   d}t jt|d tjd| |d W d    d S 1 sw   Y  d S Nz?Worksheet index 3 is invalid|Worksheet named 'Sheet4' not foundro   r>  r   r   )rV   r   rr   rw   r#   r#   r$   test_bad_sheetname_raisesN  s   "z%TestReaders.test_bad_sheetname_raisesc                 C  sV   d| }d g d}tjt|d t| W d    d S 1 s$w   Y  d S )Nrk   |)z(No such file or directoryu   没有那个文件或目录zFile o directory non esistente)ro   )joinr&   ru   FileNotFoundErrorrR   rQ   )rV   r   Zbad_filerp   r#   r#   r$   test_missing_file_raisesX  s   
"z$TestReaders.test_missing_file_raisesc                 C  s   d}|d u rt }d}n"|dkrddlm} |}d}n|dkr)ddlm} |}d	}nt}d
}tj||d t	t
| W d    d S 1 sGw   Y  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'r   CalamineErrorzCannot detect file formatzFile is not a zip filero   )r   r   rS  r   rU  r	   r&   ru   rR   rQ   r   )rV   r"   Z
bad_streamerrorrw   rS  rU  r#   r#   r$   test_corrupt_bytes_raisese  s&   "z%TestReaders.test_corrupt_bytes_raisesc                 C  sh   t d| d}|j| d W d    n1 sw   Y  t|j}td| }t|| d S )Nrb   rc   )content)rf   Zserve_contentreadrR   rQ   urlr   r   )rV   Z
httpserverr   rh   	url_tablelocal_tabler#   r#   r$   test_read_from_http_url  s   z#TestReaders.test_read_from_http_urlc                 C  s~   t d| d}|jd| |d W d    n1 sw   Y  d|j d| }tj||d}td| }t|| d S )Nrb   rc   KeyZBodys3:///test1)Zstorage_options)rf   
put_objectrC   rR   rQ   r   r   )rV   r   s3_public_buckets3sorh   rZ  r[  r\  r#   r#   r$   test_read_from_s3_url  s   z!TestReaders.test_read_from_s3_urlc           	      C  s   t d| d}|jd| |d W d    n1 sw   Y  dd l}|jdi |}| d|j d| }t|}W d    n1 sHw   Y  td| }t|| d S )Nrb   rc   r^  r   r`  ra  r#   )	rf   rb  s3fsZS3FileSystemrC   rR   rQ   r   r   )	rV   r   rc  rd  rh   rf  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y5   dt  }t	
d|  Y nw t|| d S )Nr5   r6   rP   rb   zfile://localhost/ zfailing on )ospathrP  rR   rQ   r   platformunamestripr&   r  r   r   )rV   r   r:   Z
localtabler\  r[  Zplatform_infor#   r#   r$   test_read_from_file_url  s   
z#TestReaders.test_read_from_file_urlc                 C  sD   d| }t j|ddd}td| }t j|ddd}t|| d S r   )rR   rQ   r   r   r   )rV   r   str_pathr@   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   )localrb   rq   r   )	Zpy.pathrr  ri  rj  rP  rR   rQ   r   r   )rV   r   Z	LocalPathro  r@   rp  r   r#   r#   r$   test_read_from_py_localpath  s   z'TestReaders.test_read_from_py_localpathc                 C  sZ   t jd| }t|d}tj|ddd}~|  W d    d S 1 s&w   Y  d S )Nrb   rc   rq   r   r   )ri  rj  rP  rf   rR   rQ   rY  )rV   r   ro  rh   r   r#   r#   r$   test_close_from_py_localpath  s   
"z(TestReaders.test_close_from_py_localpathc                 C  s   t || |dkr|dkr|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   r   z0ODS file contains bad datetime (seconds as text)rF   ZTimerd   r   ry   -   8   i r      1   i@ r
     *   i    9   #   i 	   )      i           i'	 r   i`
 5   i 5    %   r   i       6   Z
times_1900rq   r   Z
times_1904)rK   rH   r&   rI   rJ   r   r   r   rR   rQ   r   r   )rV   r0   r"   r   r@   r   r#   r#   r$   test_reader_seconds  s6   


zTestReaders.test_reader_secondsc           	   	   C  sJ  t || t||}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}||d
  d| d||d
 < tj|dddgdd}t	
|| ||_g d|_tj|dddgd}t	
|| ||_tj|dddgddgd}t	
|| g d|_|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 )*Nrk   barr   r   testmultiindexrd   r   
2015-01-01Tr   r   
2015-01-02Fry   r   
2015-01-03r   r   
2015-01-04r   r   r   	mi_columnr   )rr   rA  r9   r   mi_indexr   bothrr   r9   rA  ilvl1ilvl2Zmi_index_namec1c2mi_column_name)levelZname_with_intZ	both_nameZboth_name_skiprows)rr   r9   rA  r~   )rK   r?   r   from_productr   rR   r  r   rQ   r   r   rB   r   Z	set_namesr5  r   Z
set_levels)	rV   r0   r"   r   rD   mimi_filer@   r   r#   r#   r$   test_read_excel_multiindex  sn   

"	

z&TestReaders.test_read_excel_multiindexzsheet_name,idx_lvl2Zboth_name_blank_after_mi_namer   r   Zboth_name_multiple_blanksr   c              	   C  s   t || d| }tjddgddggddgd}t||}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g d|fddgdd}	|	|d  d| d|	|d < tj	||dd	gdd	gd}
t
|
|	 d S )Nr  rk   r  r   r   r  r  r   rd   r   r  Tr   r   r  Fry   r   r  r   r   r  )rk   rk   r  r  r  r  r   r   r   r   r  )rK   r   r  r?   r   rR   r  from_arraysr   rQ   r   r   )rV   r0   r"   r   rr   Zidx_lvl2r  r  rD   r@   ri   r#   r#   r$   +test_read_excel_multiindex_blank_after_nameN  s0   


"z7TestReaders.test_read_excel_multiindex_blank_after_namec                 C  sP   d| }t j|dddgd}tddg}tg dgd	 |d
}t|| d S )Nr  index_col_noner   rd   rr   rA  r   r   keyvalr   r   r   )rR   rQ   r   r  r   r   r   )rV   r   r  ri   Zexp_columnsr@   r#   r#   r$   &test_read_excel_multiindex_header_onlyv  s
   z2TestReaders.test_read_excel_multiindex_header_onlyc           	      C  s  d| }t jt jt jt jt jt jgg dg dg dg dg dgtd}g d}tg d	g d
gg dg dgd d gd}tg d	d d}t|||d}tj|ddd}t	
|| ||_tj|dddgd}t	
|| t g dg dg dg dg dg}g d}tg dg dgg dg dgd d gd}tg dd d}t|||d}tj|ddd}t	
|| ||_tj|dddgd}t	
|| d S )NZtest_index_name_pre17)ZR0C0ZR0C1ZR0C2ZR0C3ZR0C4)ZR1C0ZR1C1ZR1C2ZR1C3ZR1C4)ZR2C0ZR2C1ZR2C2ZR2C3ZR2C4)ZR3C0ZR3C1ZR3C2ZR3C3ZR3C4)ZR4C0ZR4C1ZR4C2ZR4C3ZR4C4r   )ZC_l0_g0ZC_l0_g1ZC_l0_g2ZC_l0_g3ZC_l0_g4)ZR0R_l0_g0R_l0_g1R_l0_g2R_l0_g3R_l0_g4)ZR1R_l1_g0R_l1_g1R_l1_g2R_l1_g3R_l1_g4)r   rd   r   ry   r   r   r   r   rB   r   Zsingle_namesr   r   Zmulti_namesrd   )r  r  r  r  r  )r  r  r  r  r  )r   rd   r   ry   r   Zsingle_no_namesZmulti_no_names)r   r  r   r+  r   r   r   rR   rQ   r   r   rB   )	rV   r   rH  r6   r   r  sir@   r   r#   r#   r$   test_excel_old_index_format  sf   	z'TestReaders.test_excel_old_index_formatc              	   C  sR   d}dD ]"}t jt|d tjd| |d W d    n1 s!w   Y  qd S )Nz#Passing a bool to header is invalid)TFro   rb   rA  r   )rV   r   rw   argr#   r#   r$   test_read_excel_bool_header_arg  s   z+TestReaders.test_read_excel_bool_header_argc              	   C  st  t || t||}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g dd}|d d| d|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g dd}tdd
tddgddtddgddtdd	ggg dd}|d d| d|d< t|| d S )Ntestskiprowsskiprows_listr   r   rr   r~   rd   r   r  Tr   r  Fry   r   r  r   r   r  r   r   r   r   r   c                 S     | dv S N)r   r   r#   r   r#   r#   r$   r     rB  z6TestReaders.test_read_excel_skiprows.<locals>.<lambda>)rr   r~   r   )rK   r?   rR   rQ   r   r  r   r   r   r   r  rV   r0   r"   r   rD   r   r@   r#   r#   r$   test_read_excel_skiprows  sT   

		z$TestReaders.test_read_excel_skiprowsc                 C  s   t || t||}tjd| ddd d}tddtdd	gd
dtddggg dd}|d d| d|d< t|| d S )Nr  r  c                 S  s   | dvS )N)rd   ry   r   r#   r   r#   r#   r$   r     rB  zFTestReaders.test_read_excel_skiprows_callable_not_in.<locals>.<lambda>r  rd   r   r  Try   r   r  Fr   r   r   r   r   )	rK   r?   rR   rQ   r   r  r   r   r   r  r#   r#   r$   (test_read_excel_skiprows_callable_not_in  s   

	z4TestReaders.test_read_excel_skiprows_callable_not_inc                 C  s@   d}t jd| |d}t d| }|d | }t|| d S )Nr   rb   nrowsr  )rV   r   num_rows_to_pullr   r@   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 )Nrb   r   r  )rR   rQ   r   r   r   )rV   r   r@   Znum_records_in_filer  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  sJ   d}t jt|d tjd| dd W d    d S 1 sw   Y  d S )Nz'nrows' must be an integer >=0ro   rb   r   r  r   r   r#   r#   r$   +test_read_excel_nrows_non_integer_parameter-  s   "z7TestReaders.test_read_excel_nrows_non_integer_parameterz-filename,sheet_name,header,index_col,skiprowsr  r  r  r  r  r  r  c                 C  r  r  r#   r   r#   r#   r$   r   ;  rB  zTestReaders.<lambda>c           	      C  sL   t j|| ||||djdd }t j|| ||||dd}t|| dS )z
        For various parameters, we should get the same result whether we
        limit the rows during load (nrows=3) or after (df.iloc[:3]).
        )rr   rA  r9   r~   Nry   )rr   rA  r9   r~   r  )rR   rQ   r   r   r   )	rV   r   rH  rr   rA  r9   r~   r@   r   r#   r#   r$   test_read_excel_nrows_params3  s$   z(TestReaders.test_read_excel_nrows_paramsc                 C  sF   t jtdd td| dd W d    d S 1 sw   Y  d S )Nzbut 3 positional argumentsro   rb   rq   r   r   rD  r#   r#   r$   test_deprecated_kwargsW  s   "z"TestReaders.test_deprecated_kwargsc                 C  sV   d| }g d}t jg ddd}t||dd}tj|dd	d
gd d}t|| d S )Nr  ))r   r   r  ry   r   r  ))r   r   r  rd   r   r  )r   rd   r  )r   ry   r  r  r   rd   r  )r   from_tuplesr   rR   rQ   r   r   )rV   r   	file_namer6   idxr@   ri   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      ?rd   r   numbersr   )r   r   r   rR   rQ   r   r   )rV   r   r  r6   r@   ri   r#   r#   r$   test_one_col_noskip_blank_lineh  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 )Nr  )r   r   )r   r   rd   ry   r   r   r   Zmi_column_empty_rowsr   r  )	r   r  r   r   r   rR   rQ   r   r   )rV   r   r  r   r6   r@   ri   r#   r#   r$    test_multiheader_two_blank_linesp  s   $
z,TestReaders.test_multiheader_two_blank_linesc                 C  s$   d| }t |}|jdksJ 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)ry   ry   N)rR   rQ   shape)rV   r   r  ri   r#   r#   r$   test_trailing_blanks{  s   
z TestReaders.test_trailing_blanksc                 C  t   |dkr	t d |dkr|t jjdd t jtdd tjd| d	d
 W d    d S 1 s3w   Y  d S )Nr   *chartsheets do not exist in the ODF formatr   4pyxlsb can't distinguish chartsheets from worksheetsrF   z"Worksheet named 'Chart1' not foundro   
chartsheetZChart1r   	r&   r  rH   rI   rJ   ru   r   rR   rQ   rV   r0   r"   r   r#   r#   r$   test_ignore_chartsheets_by_str  s   
"z*TestReaders.test_ignore_chartsheets_by_strc                 C  r  )Nr   r  r   r  rF   z0Worksheet index 1 is invalid, 1 worksheets foundro   r  rd   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g dg dg dgg dd	}t|| d S )
NZtest_decimal,rd   )decimalr~   )rd   gAc̝ė@g	hAABCZpoig2[j@)r   gHzG^@g{G@ZDEFZuytgUq&?)ry   g%Cq@g^@ZGHIZrezg)@)ZIdZNumber1ZNumber2ZText1ZText2ZNumber3r   r   r   r#   r#   r$   test_euro_decimal_format  s   z$TestReaders.test_euro_decimal_format)Y__name__
__module____qualname__r&   fixturerY   rj   rx   r   r   r   rI   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.  r9  r;  r=  r?  r@  rE  filterwarningsrF  rI  rK  rL  rN  rR  rW  network
single_cpur]  tdZskip_if_not_us_localere  rg  Zslowrn  rq  
skip_if_nors  rt  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r#   r#   r#   r$   rL      s   

3(

	

	2
0









	$T
!I6
	rL   c                
   @  s   e Zd Zdd Zejdddd Zdd Zd	d
 Zej	
dg d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d$d% Zej	
d&d'd(gd)d* Zd+d, Zd-d. Zd/d0 Zd1d2 Zd3S )4TestExcelFileReadc              	   C  s   d}t jt|dd1 td| d}tj| |d W d    n1 s&w   Y  W d    d S W d    d S 1 s>w   Y  d S )NzPassing bytes to 'read_excel' is deprecated and will be removed in a future version. To read from a byte string, wrap it in a `BytesIO` object.F)rp   Zraise_on_extra_warningsrb   rc   rO   )r   assert_produces_warningFutureWarningrf   rR   rQ   rY  )rV   r"   r   rw   rh   r#   r#   r$   test_deprecate_bytes_input  s   "z,TestExcelFileRead.test_deprecate_bytes_inputTrM   c                 C  rN   )zH
        Change directory and set engine for ExcelFile objects.
        rO   r5   r6   rP   re   N)r   rR   re   rS   rT   rU   r#   r#   r$   rY     rZ   z#TestExcelFileRead.cd_and_set_enginec                 C  sr   dddddd}t d| }|j}W d    n1 sw   Y  |d ur)|}n||dd   }||ks7J d S )Nr   r   r   r   r_   rb   rd   )rR   re   r"   )rV   r   r"   rg   rP   ri   r@   r#   r#   r$   rj     s   z"TestExcelFileRead.test_engine_usedc                 C  s  t d| }t j|dddgd}W d    n1 sw   Y  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 d    n1 sUw   Y  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 d    n1 sw   Y  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 d    n1 sw   Y  ttjgdgtjgtjgdggd	gd
}t|| d S )NZtest4rq   Fapplerr   Zkeep_default_naZ	na_valuesr  rd   rabbitr   r   Ttest51.#QNANr   )rR   re   rQ   r   r   r   r   r   )rV   r   rP   r   r@   r#   r#   r$   test_excel_passes_na  sH   

 

 z&TestExcelFileRead.test_excel_passes_na	na_filter)NTFc                 C  s   i }|d ur
||d< t d| }t j|fdddgd|}W d    n1 s*w   Y  |du r@d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  rq   Tr  r  Fr  rd   r   r  r   r   )rR   re   rQ   r   r   r   r   r   )rV   r   r  r\   rP   r   r@   r#   r#   r$   test_excel_passes_na_filter  s&   	z-TestExcelFileRead.test_excel_passes_na_filterc           
      C  s  t || |}t||| td| }tj|ddd}tj|ddgdd}W d    n1 s1w   Y  t|| t|| td| }|jddd}|jddgdd}W d    n1 sdw   Y  t|| t|| td| }tj|dddd}	W d    n1 sw   Y  t|	|jd d	  td| }|jdddd
}	W d    n1 sw   Y  t|	|jd d	  d S )Nrb   r   r   rd   r   )r9   )r~   r9   r   r   )r9   r   )	rK   rE   rR   re   rQ   r   r   r^   r   )
rV   r0   r"   r   r<   r@   rP   r   r   r   r#   r#   r$   test_excel_table_sheet_by_index  s.   
z1TestExcelFileRead.test_excel_table_sheet_by_indexc                 C  s   t || |}t||| d}d}t|| }|j|dd}	W d    n1 s*w   Y  t|| }|jd|d}
W d    n1 sHw   Y  t|	| t|
| d S rG  )rK   rE   rR   re   r^   r   r   )rV   r0   r"   r   r<   r@   rH  rr   rP   Z	df1_parseZ	df2_parser#   r#   r$   rI  2  s   
z!TestExcelFileRead.test_sheet_namerr   ry   r   r   rq   c              	   C  s   d}t jt|d. td| }|j|d W d    n1 s"w   Y  W d    d S W d    d S 1 s:w   Y  d S rM  )r&   ru   r   rR   re   r^   )rV   r   rr   rw   rP   r#   r#   r$   rN  D  s   "z+TestExcelFileRead.test_bad_sheetname_raisesc              	   C  s   d| }t j|dd|d}t|d%}t |}t j|ddd}W d    n1 s+w   Y  W d    n1 s:w   Y  t|| d S )Nrb   rq   r   rr   r9   r"   rc   r   )rR   rQ   rf   re   r   r   )rV   r"   r   rJ  r@   rh   ra   r   r#   r#   r$   rK  O  s   z(TestExcelFileRead.test_excel_read_bufferc              	   C  sx   t d| d&}t|}tj|dd|d W d    n1 s!w   Y  W d    n1 s0w   Y  |js:J d S )Nrb   rc   rq   r   r  )rf   rR   re   rQ   closed)rV   r"   r   rh   r`   r#   r#   r$   test_reader_closes_fileY  s   z)TestExcelFileRead.test_reader_closes_filec              	   C  s   d}t d| /}tjt|d t j|dd W d    n1 s#w   Y  W d    d S W d    d S 1 s;w   Y  d S )Nz8Engine should not be specified when passing an ExcelFilerb   ro   rk   rO   )rR   re   r&   ru   r   rQ   )rV   r   rw   Zxlr#   r#   r$   test_conflicting_excel_enginesa  s   "z0TestExcelFileRead.test_conflicting_excel_enginesc                 C  sj   t jd| |d}td| d}| }W d    n1 sw   Y  t jt||d}t|| d S )Nrb   rO   rc   )rR   rQ   rf   rY  r   r   r   )rV   r"   r   r@   rh   r6   r   r#   r#   r$   test_excel_read_binaryi  s   
z(TestExcelFileRead.test_excel_read_binaryc                 C  s^   t d| d}tj||d}W d    n1 sw   Y  tjd| |d}t|| d S )Nrb   rc   rO   )rf   rR   rQ   r   r   )rV   r   r"   rh   ri   r@   r#   r#   r$   %test_excel_read_binary_via_read_excels  s
   z7TestExcelFileRead.test_excel_read_binary_via_read_excelc              	   C  s   t dd1}tjtdd tj|ddgd W d    n1 s!w   Y  W d    d S W d    d S 1 s9w   Y  d S )Nzdf_header_oob.xlsxrc   zexceeds maximumro   r   rd   r  )rf   r&   ru   r   rR   rQ   )rV   r"   rh   r#   r#   r$   )test_read_excel_header_index_out_of_rangez  s   "z;TestExcelFileRead.test_read_excel_header_index_out_of_rangerH  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I2r   r  )r   zB.1ZI11ZI12r  rd   ry   r   )rB   r   r   rq   r   r  )r   r   r  r   rR   rQ   r   r   )rV   rH  r  colsr@   ri   r#   r#   r$   test_header_with_index_col  s   z,TestExcelFileRead.test_header_with_index_colc                 C  s   t || d| }t|}tj|ddgd|d}W d    n1 s$w   Y  t||}tjddgd| dd	}tj|d d |dd  g|d  |d  gd
}	t	g g |	d}
t
|
| d S )NZtest_datetime_mir   rd   )rA  r9   r"   z
2020-02-29z
2020-03-01r   r   r   r  r  )rK   rR   re   rQ   r?   ZDatetimeIndexr   r  Zto_pydatetimer   r   r   )rV   r0   r"   r   rh   rP   r   rD   ZdtiZexpected_column_indexr@   r#   r#   r$   test_read_datetime_multiindex  s   



z/TestExcelFileRead.test_read_datetime_multiindexc              	   C  sx   t jtdd+ td| dd W d    n1 sw   Y  W d    d S W d    d S 1 s5w   Y  d S )NzValue must be one of *ro   zio.excelz.readerabc)r&   ru   r   rR   r(  rD  r#   r#   r$   test_engine_invalid_option  s   "z,TestExcelFileRead.test_engine_invalid_optionc                 C  sr   |dkr	t d |dkr|t jjdd td| }|jdgks'J W d    d S 1 s2w   Y  d S )Nr   r  r   r  rF   r  rq   )r&   r  rH   rI   rJ   rR   re   Zsheet_names)rV   r0   r"   r   rP   r#   r#   r$   test_ignore_chartsheets  s   
"z)TestExcelFileRead.test_ignore_chartsheetsc              
   C  s   t f}|d u rtd|  n|dkrdd l}t |jjf}n|dkr,ddlm} |f}t	d| B}t
|jddd td	 z	tj||d
 W n	 |yV   Y nw W d    n1 saw   Y  W d    d S W d    d S 1 syw   Y  d S )NzInvalid test for engine=r   r   r   rT  Zcorruptzutf-8)encodingFrO   )r	   r&   r  r   ZbiffhrS  r   rU  r   r  r   
write_textr  rR   re   )rV   r"   r   errorsr   rU  filer#   r#   r$   test_corrupt_files_closed  s,   "z+TestExcelFileRead.test_corrupt_files_closedN)r  r  r  r  r&   r  rY   rj   r  rI   r  r  r  rI  rN  rK  r  r  r  r  r  r   r  r  r  r	  r#   r#   r#   r$   r    s6    

&





r  )r   r   r   r    )r   r   r"   r=   r   r   )r@   r   r   r   r"   r   r   rA   )8
__future__r   r   r   	functoolsr   r5   r   ri  pathlibr   rk  rs   urllib.errorr   zipfiler	   numpyr   r&   Zpandas.compatr
   Zpandas.util._test_decoratorsutilZ_test_decoratorsr  ZpandasrR   r   r   r   r   r   Zpandas._testingZ_testingr   rI   r  Z
pytestmarkr*   r'   r  Zengine_paramsr%   r)   r  r   r1   r"   r   r<   r?   rE   rK   rL   r  r#   r#   r#   r$   <module>   s    


	



	
	          