o
    Ti-                     @   sb  d dl Z d dlZd dlZd dlZd dlmZ d dlZd dlm	Z	m
Z
mZmZmZmZmZ d dlmZmZ d dlmZ ejjZdd Zdd	 Zd
d Zdd Zdd Zdd Zej dd Z!dd Z"ej#ddej$gdej%gdej&gdej'gdej$gdej%gdej&gdej'gdej(gdej(gg
ej)ddd Z*dd Z+dd Z,ej#d ddgd!d" Z-dS )#    N)	Timestamp)	DataFrameHDFStoreIndex
MultiIndexSeries_testingconcat)_maybe_removeensure_clean_store)_test_decoratorsc                 C   s   t dddgi}t| | -}|jd|dd |jd|dd |djdks)J |djdks3J W d    d S 1 s>w   Y  d S )	NA      afixedformatbtable)r   r   put
get_storerZformat_type)tmp_path
setup_pathdfstore r   a/var/www/html/evchargy.com/venv/lib/python3.10/site-packages/pandas/tests/io/pytables/test_put.pytest_format_type   s   "r   c                 C   sH   d}t jt|d t| | dd W d    d S 1 sw   Y  d S )Nz-format is not a defined argument for HDFStorematchr   r   )pytestraises
ValueErrorr   )r   r   msgr   r   r    test_format_kwarg_in_constructor&   s   "r%   c              
   C   s  t |}t }tdd: t|d |d| |djr#J d}t	j
t|d |d| W d    n1 s=w   Y  W d    n1 sLw   Y  tdd. t|d |d| |djskJ t|d |d| |djs~J W d    n1 sw   Y  W d    n1 sw   Y  | | }t }tddI ||d t|}|djrJ W d    n1 sw   Y  t	j
t|d |j|ddd	 W d    n1 sw   Y  W d    n1 sw   Y  tdd[ ||d
 t|}|d
jsJ W d    n	1 s!w   Y  |j|ddd	 t|}|djs<J W d    n1 sGw   Y  W d    d S W d    d S 1 s`w   Y  d S )Nzio.hdf.default_formatr   r   Can only append to Tablesr   df2r   Tappenddf3Zdf4)r   tmZmakeDataFramepdZoption_contextr
   r   r   Zis_tabler!   r"   r#   r)   to_hdfr   )r   r   r   r   r$   pathr   r   r   test_api_default_format/   s\   

	




 $r/   c              	   C   s  t | }t }t }||d< |d d |d< |d d |d< |d d |d< |d d |d< |jd|d d dd	 d
}tjt|d |jd|dd  dd W d    n1 s]w   Y  t|d tjt|d |jd|dd  dd W d    n1 sw   Y  tjt|d |jd|dd  dd W d    n1 sw   Y  |jd|d d ddd t	|d d |d  W d    d S 1 sw   Y  d S )Nr   
   r   zfoo/bar/bahfooz/foocr   r   r&   r   Tr(   fF)r   r)   )
r   r+   ZmakeTimeSeriesmakeTimeDataFramer   r!   r"   r#   r
   assert_frame_equal)r   r   tsr   r$   r   r   r   test_putY   s.   

"r7   c                 C   s   t | r}tdd tdD }ttd|d}t||d}||d< t|d | ||d< t	|d | tdgd	d tdD  }ttd
|d}t||d}||d< t|d | ||d< t	|d | W d    d S 1 syw   Y  d S )Nc                 S      g | ]}d | qS zI am a very long string index: r   .0ir   r   r   
<listcomp>z       z)test_put_string_index.<locals>.<listcomp>   index)r   Br   r   Z$abcdefghijklmnopqrstuvwxyz1234567890c                 S   r8   r9   r   r:   r   r   r   r=      r>      )
r   r   ranger   nparanger   r+   assert_series_equalr5   )r   r   rA   sr   r   r   r   test_put_string_indexx   s(   
"rI   c              	   C   s   t | H}t }|jd|ddd t|d | d}tjt|d |jd|ddd W d    n1 s7w   Y  W d    d S W d    d S 1 sOw   Y  d S )	Nr2   r   zlibr   Zcomplib0Compression not supported on Fixed format storesr   r   r   )r   r+   r4   r   r5   r!   r"   r#   )r   r   r   r$   r   r   r   test_put_compression   s   
"rM   c              	   C   s   t  }t| <}d}tjt|d |jd|ddd W d    n1 s&w   Y  |jd|ddd t |d | W d    d S 1 sGw   Y  d S )	NrL   r   r   r   ZbloscrK   r2   r   )r+   r4   r   r!   r"   r#   r   r5   )r   r   r   r$   r   r   r   test_put_compression_blosc   s   
"rN   c              	   C   sD  t  }d|d< d|d< |d dk|d< |d dk|d	< d
|d< d|d< d|d< tdd|d< tdd|d< tdd|d< tdd|d< tj|j|jdd dgf< | }t	| 6}t
|d t tjj |d| W d    n1 sw   Y  |d}t || W d    d S 1 sw   Y  d S )Nr1   Zobj1barobj2r   r   Zbool1rB   Zbool2TZbool3r   Zint1r   Zint2Z20010102nsZ
timestamp1Z20010103Z
timestamp2Z	datetime1Z	datetime2      r   )r+   r4   r   Zas_unitrE   nanlocrA   Z_consolidater   r
   Zassert_produces_warningr,   errorsZPerformanceWarningr   getr5   )r   r   r   expectedr   r   r   test_put_mixed_type   s,   


"rY   zformat, indexr   r   z3ignore:PeriodDtype\[B\] is deprecated:FutureWarningc                 C   s   t | 4}ttjddtdd}|t||_t	|d |j
d||d t||d  W d    d S 1 s;w   Y  d S )Nr   )r0   r   ZABcolumnsr   r   )r   r   rE   randomdefault_rngstandard_normallistlenrA   r
   r   r+   r5   )r   r   rA   r   r   r   r   r   test_store_index_types   s   

"ra   c              	   C   s*  t jg dddgd}ttddd|d}||j }t	| w}|
d	| tj|d	 |d
d
d |j
d|dd tj|d |d
d
d td}tjt|d |j
d|ddgd W d    n1 sjw   Y  td}tjt|d |j
d|dd
d W d    n1 sw   Y  W d    n1 sw   Y  t	|  }|d| |d| t|d t||f W d    n1 sw   Y  ttdddttdddd}||j }t	| }|j
d|dd tj|d |d
d
d W d    d S 1 sw   Y  d S )N))r   r   )r   r   )rB   r   )rB   r   firstsecondnames   rR      rZ   r   T)Zcheck_index_typeZcheck_column_typeZdf1r   r   z<cannot use a multi-index on axis [1] with data_columns ['A']r   r'   r   )r   Zdata_columnsz;cannot use a multi-index on axis [1] with data_columns Truer*   ZABCDr1   )name)r   from_tuplesr   rE   rF   ZreshapeZset_axisrA   Zto_numpyr   r   r+   r5   reescaper!   r"   r#   r)   r	   r   r_   )r   rA   r   rX   r   r$   r   r   r   test_column_multiindex   sJ   



&
$rl   c              	   C   s6  t | }ddd}t|d ttdddg| d}|d| t|d| t|d ttdddg|g dd}|d| t|d| t|d	 t	td
|g dd}|d	| t	td
|g dd}t
|d	| t|d ttdddg|g dd}d}tjt|d |d| W d    n1 sw   Y  t|d ttdddg|g dd}tjt|d |d| W d    n1 sw   Y  t|d ttdddg|g dd}|d| t|d| W d    d S 1 sw   Y  d S )Nc                 S   s   t jdd tddD | dS )Nc              	   S   s<   g | ]}t d D ]}t dD ]}tdd|||fqqqS )r   rR   i  rf   )rD   datetime)r;   drH   tr   r   r   r=     s    
z=test_store_multiindex.<locals>.make_index.<locals>.<listcomp>r   rR   rd   )r   ri   rD   rd   r   r   r   
make_index  s   z)test_store_multiindex.<locals>.make_indexr   )rf   r   r   r   )r[   rA   )dateNNrH   rf   r@   )rq   Zlevel_1Zlevel_2)rq   r   ro   zBduplicate names/columns in the multi-index when storing as a tabler   )rq   rq   rq   )rq   rH   ro   )N)r   r
   r   rE   Zzerosr)   r+   r5   selectr   rG   r!   r"   r#   )r   r   rp   r   rH   Zxpr$   r   r   r   test_store_multiindex  s^   










$rs   r   c                 C   s\   t tjddtjddddd}| | }|j|dd	|d
 t|d}t	
|| d S )Nr   )   r   Z20220101Mrt   )freqZperiodsr@   r   w)moder   )r   rE   r\   r]   r^   r,   Zperiod_ranger-   Zread_hdfr+   r5   )r   r   r   r   r.   rX   r   r   r   test_store_periodindex[  s   ry   ).rm   rj   numpyrE   r!   Zpandas._libs.tslibsr   Zpandasr,   r   r   r   r   r   r   r+   r	   Zpandas.tests.io.pytables.commonr
   r   Zpandas.utilr   tdmarkZ
single_cpuZ
pytestmarkr   r%   r/   r7   rI   rM   Zskip_if_windowsrN   rY   ZparametrizeZmakeFloatIndexZmakeStringIndexZmakeIntIndexZmakeDateIndexZmakePeriodIndexfilterwarningsra   rl   rs   ry   r   r   r   r   <module>   sN    $	
	*

.G