o
    %jQ8                  	   @   s"  d dl Zd dlZd dlm  mZ d dlmZm	Z	m
Z
mZmZmZmZmZmZmZmZmZmZmZ d dlmZ dd Zdd Zdd Zd	d
 Zdd Zdd Zdd Zdd Z dd Z!dd Z"dd Z#dd Z$dd Z%dd Z&dd  Z'd!d" Z(ej)ej*+d#d$d%gej*+d&d'd ed gd(d) Z,d*d+ Z-d,d- Z.ej*+d.ed/d0ed1d0ged/d0ed1d0d2gd3d3gd3d3ej/gfed/d0ed1d0ged/d0ed1d0gd3d3gd3d3gfgd4d5 Z0d6d7 Z1d8d9 Z2d:d; Z3ej*+d<d=gd>ggg g ggd?d@ Z4dAdB Z5dCdD Z6ej*+d#dEdFgdGdH Z7dS )I    N)NACategoricalFloat64DtypeIndex
MultiIndexNaTPeriodPeriodIndex
RangeIndexSeries	Timedelta	Timestamp
date_rangeisnac                 C   s(  | |j}t|j|jsJ |j|jsJ |j|js"J |jdd }| |}| D ]\}}||| ks>J q2| jdd }|  |}| D ]\}}|| | ks[J qO|  |}	t|		 sjJ | jd d d }
|  |
}| D ]\}}|| | ksJ q{|   }|| usJ d S )N
         )
reindexindextmZshares_memoryis_Z	identicalitemsnpisnanall)datetime_seriesZstring_seriesidentityZsubIndexZ	subSeriesidxvalZ	subIndex2ZsubTSZstuffSeriesZnonContigIndexZsubNonContigresult r    i/var/www/html/Deteccion_Ine/venv/lib/python3.10/site-packages/pandas/tests/series/methods/test_reindex.pytest_reindex   s(   



r"   c                  C   s   t g dddtjdgd} tjdtjddtjgg d}}t| || j|  | jd| _tj| || j| dd	 d S )
N)r                     r   )r   r   r   r#   r&   r   objectF)Zcheck_index_type)	r   r   nanr   assert_series_equalr   Zilocr   astype)tsijr    r    r!   test_reindex_nan;   s
     r1   c                  C   sp   t dddd} t| }|td}t|jtdsJ | }|dd   s,J |d d 	 r6J d S )Nz1/1/2000 00:00:00r   Z10speriodsfreq   zM8[ns])
r   r   r   ranger   Z
issubdtypedtyper   r   any)rngZseriesr   maskr    r    r!   test_reindex_series_add_natG   s   r<   c                  C   s   t ddd} ttjdd| d}|t|jdd }|dd }|j	d |_t
|| |t|jdd  }t
|| d S )Nz1/1/2000r   r3   r   r)   r$   r   )r   r   r   randomZdefault_rngZstandard_normalr   listr   
_with_freqr   r,   )r:   r.   r   expectedr    r    r!   test_reindex_with_datetimesS   s   rB   c                 C   s   t g d}|j| jdd |j| jdd}| t| j}| jd | _t| | | d d d }d}tjt	|d |j| jdd W d    d S 1 sNw   Y  d S )Nr)   padmethodr   zVInvalid fill method\. Expecting pad \(ffill\), backfill \(bfill\) or nearest\. Got foomatchfoo)
r   r   r   r?   r@   r   r,   pytestraises
ValueError)r   empty	reindexedr.   msgr    r    r!   test_reindex_corner`   s   
"rO   c                  C   sh   t tddd} | d d d }|j| jdd}|j| jdd}t|| t g d}t|| d S )	Nr   int64r8   r   rC   rD   ffill)
r   r   r   r   r'   r'      rS   r(   r(   )r   r   aranger   r   r   r,   )ss2rM   Z
reindexed2rA   r    r    r!   test_reindex_padw   s   rW   c                  C   s   t g dg dd} g d}t g d|d}| | }t||d d}tjt|d | |jd	d
}W d    n1 sCw   Y  t|| t g d|d}| j|dd}t|| d S )Nr&   r   r#   r'   r$   )abcder)   )rY   gr[   f)r&   r&   r#   r#   float64z-The 'downcast' keyword in ffill is deprecatedrF   Zinfer)Zdowncast)r&   r$   r#   r$   rR   rD   )r   r   rR   r   r,   r-   assert_produces_warningFutureWarning)rU   	new_indexrA   r   rN   r    r    r!   test_reindex_pad2   s   rd   c                  C   s   t g dtdd} d}d}tjt|d | t| }W d    n1 s)w   Y  t g dt|d}t|| d S )N)TFFTabcdr)   Zagc"Downcasting object dtype arrays onrF   )TTF)r   r?   r   ra   rb   r   rR   r,   )rU   rc   rN   r   rA   r    r    r!   test_reindex_inference   s   rg   c                  C   sp   t dtdd} d}tjt|d | d }W d    n1 s#w   Y  t dtdd}t|| d S )NFr$   r)   rf   rF   r&   )r   r7   r   ra   rb   shiftZbfillr,   )rU   rN   r   rA   r    r    r!   test_reindex_downcasting   s   ri   c                  C   s   t tjddd} g d}| j|dd}t t|d|}t|| | j|ddd}t d	d
tjdg|}t|| | j|dg dd}t d	tjtjdg|}t|| d S )Nr   rP   rQ   )g?g?g      ?       @nearestrD   g?)rE   Z	tolerancer   r&   r   )g333333?g{Gz?g?r#   )	r   r   rT   r   aroundr-   r   r,   r+   )rU   targetr   rA   r    r    r!   test_reindex_nearest   s   rn   c                 C   st   | d d d }t tjt|td|jd}|| j}|jtjks#J ||jd d d }|jttks8J d S Nr   rQ   r)   )	r   r   zeroslenintr   r   r8   r`   )r   r.   Zint_tsZreindexed_intr    r    r!   test_reindex_int   s   rs   c                 C   sp   | d d d }t tjt|td|jd}|| j}|jtjks#J ||jd d d }|jtj	ks6J d S ro   )
r   r   rp   rq   boolr   r   r8   Zobject_Zbool_)r   r.   bool_tsZreindexed_boolr    r    r!   test_reindex_bool   s   rv   c                 C   sT   | dd  }t tjt|td|jd}|j| jdd}t|d d  s(J d S )Nr$   rQ   r)   rC   rD   )	r   r   rp   rq   rt   r   r   r   r   )r   r.   ru   Zfilled_boolr    r    r!   test_reindex_bool_pad   s   rw   c                  C   s   t ddd} tg ddd}|| }tttjtjtjgg dd}| |_t|| ttdd	gg dd}d
dg|_|d
dg}t|| ttd	tjgg dd}ddg|_|ddg}t|| d S )NZ20000101r#   r=   )rY   rZ   r[   categoryrQ   )values
categoriesrZ   r[   r&   r   )	r   r   r   r   r   r+   r   r   r,   )r   rU   r   rA   r    r    r!   test_reindex_categorical   s    


r{   c                  C   s`   t g dg dd} g d}d}t}| |||}| |||}t|| d S )Nr&   r   r#   )r   r   r&   r)   )r   r&   r   rx   )r   strr   r-   r   r,   )serrc   Z
temp_dtypeZ	new_dtyper   rA   r    r    r!   %test_reindex_astype_order_consistency   s   r   c                  C   s  t g d} | g d}t ddtjgg dd}t|| | jg ddd}t g dg dd}t|| t g d}|g d}t ddtjgg dd}t|| |jg ddd}t g d	g dd}t|jjtj	stJ t|| t g dt
d
}|g d}t ddtjgg dt
d}t|| |jg ddd}t g dg dt
d}t|| t g d}|g d}t ddtjgg dt
d}t|| |jg ddd}t g dg dd}t|| d S )N)      ?rj         @r|   rj   r   r)   r   
fill_value)rj   r   r   )r   r#   r   rQ   r   r#   r   r8   rH   )r   r#   rH   )TFTFT)FTF)r   r   r   r+   r   r,   
issubclassr8   typeintegerr*   )Zfloatsr   rA   ZintsobjectsZboolsr    r    r!   test_reindex_fill_value  s:   r   r8   zdatetime64[ns]timedelta64[ns]r   stringc                 C   sb   | dkr|t dkrtd}ttg| d}|jddg|d}tt|gddgtd}t|| d S )Nr   r   rQ   r&   r   r   )r   r   r   r   r   r*   r   r,   )r8   r   Zusing_array_managerr~   r   rA   r    r    r!   +test_reindex_fill_value_datetimelike_upcast9  s   r   c                  C   sr   t dddd} t dddd}ttd| d	}d
}tjt|d |j|dd W d    d S 1 s2w   Y  d S )NZ20131101zAmerica/Chicagor%   )tzr3   Z20131103r   hr2   r)   zLCannot compare dtypes datetime64\[ns, America/Chicago\] and datetime64\[ns\]rF   rR   rD   )r   r   r7   rI   rJ   	TypeErrorr   )r   ZnewidxrU   rN   r    r    r!   /test_reindex_datetimeindexes_tz_naive_and_awareI  s   "r   c                  C   s6   t ddddg} t tgd dd}t| | d S )Nzdatetime64[ns, UTC]rQ   r   r&   r   )r   r   r   r   Zassert_equal)r   rA   r    r    r!   "test_reindex_empty_series_tz_dtypeV  s   r   z+p_values, o_values, values, expected_valuesZ2019Q1zQ-DECZ2019Q2ZAllr   c           	      C   sB   t | }t|}t||d}||}t||d}t|| d S )Nr)   )r	   r   r   r   r   r,   )	Zp_valuesZo_valuesry   Zexpected_valuesZperiod_indexZobject_indexr~   r   rA   r    r    r!   $test_reindex_periodindex_with_object]  s   
r   c                  C   sT   t ddg} d}tjt|d | ddgd W d    d S 1 s#w   Y  d S )Nr&   r   zCreindex\(\) takes from 1 to 2 positional arguments but 3 were givenrF   r#   Fr   rI   rJ   r   r   r~   rN   r    r    r!   test_reindex_too_many_argsy  s
   "r   c                  C   sZ   t ddg} d}tjt|d | jddgddgd W d    d S 1 s&w   Y  d S )Nr&   r   z4reindex\(\) got multiple values for argument 'index'rF   r#   r'   r)   r   r   r    r    r!   test_reindex_double_index  s
   "r   c                  C   s@   t ddg} | jddgd}t ddgddgd}t|| d S )Nr&   r   r   r)   )r   r   r   r,   )r~   r   rA   r    r    r!   test_reindex_no_posargs  s   r   ry   rY   xc                 C   sh   t tt| d t| dd}|jtdgdd}t tdg| d gg g gddd}t	|| d S )Nr   r*   r   rZ   )levelr&   )Zlevelscodes)
r   r7   rq   r   Zfrom_arraysr   r   arrayr   r,   )ry   r~   r   rA   r    r    r!   test_reindex_empty_with_level  s   r   c                  C   sZ   t g ddd} d}tjt|d | jg ddd W d    d S 1 s&w   Y  d S )	N)r&   r   r#   r&   rx   rQ   z:Cannot setitem on a Categorical with a new category \(-1\)rF   rX   r   r   r   r    r    r!   test_reindex_missing_category  s
   "r   c                  C   s   t dtgt d} | td}|jj}tdtj	tj	g}t
|| t
d   t|}t dtj	tj	gt d}t
|| W d    d S 1 sLw   Y  d S )Nr   rQ   r#   r&   r   )r   r   r   r   r7   ry   _datar   r   r+   r   Zassert_numpy_array_equalra   logr,   )rU   Z	s_reindexr   rA   Z
result_logZexpected_logr    r    r!   #test_reindexing_with_float64_NA_log  s   
"r   Ztimedelta64Z
datetime64c                 C   s`   t tjdg|  dd}|td}t tjdtt| ddg|  dd}t|| d S )Nr&   z[s]rQ   r   ZnatrU   )r   r   r   r   r
   getattrr   r,   )r8   r~   r   rA   r    r    r!   test_reindex_expand_nonnano_nat  s   "r   )8numpyr   rI   Zpandas.util._test_decoratorsutilZ_test_decoratorstdZpandasr   r   r   r   r   r   r   r	   r
   r   r   r   r   r   Zpandas._testingZ_testingr   r"   r1   r<   rB   rO   rW   rd   rg   ri   rn   rs   rv   rw   r{   r   r   Z&skip_array_manager_not_yet_implementedmarkZparametrizer   r   r   r+   r   r   r   r   r   r   r   r   r    r    r    r!   <module>   sf    @"
3


