o
    gk                     @   s  d Z ddlmZ ddlmZ ddlmZ ddlmZ ddl	m
Z
 ddlmZmZmZmZ ddlmZmZ dd	lmZ dd
lmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlm Z m!Z!m"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-m.Z.m/Z/ ddl0m1Z1m2Z2 ddl3m4Z4 ddl5m6Z6 ddl7m8Z8m9Z9 ddl:m;Z; ddl<m=Z= ddl>m?Z? ddl@mAZAmBZBmCZCmDZD G dd deZEdd  ZFd!S )"z.Worksheet is the 2nd-level container in Excel.    )chain)
itemgetter)isgenerator)warn)
deprecated)column_index_from_stringget_column_letterrange_boundariescoordinate_to_tuple)Cell
MergedCell)ConditionalFormattingList)RelationshipList)_WorkbookChild)DefinedNameDict)
Translator   )DataValidationList)PrintPageSetupPageMarginsPrintOptions)ColumnDimensionRowDimensionDimensionHolderSheetFormatProperties)SheetProtection)
AutoFilter)Pane	SelectionSheetViewList)MultiCellRange	CellRange)MergedCellRange)WorksheetProperties)RowBreakColBreak)ScenarioList)	TableList)ArrayFormula)PrintTitlesColRangeRowRange	PrintAreac                   @   s  e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdZdZdZdZdZdZdZdddZdd Zedd Zedd  Zed!d" Zed#d$ Z ed%d& Z!ed'd( Z"e"j#dd)d(Z"dd*d+Z$d,d- Z%d.d/ Z&d0d1 Z'd2d3 Z(d4d5 Z)d6d7 Z*ed8d9 Z+ed:d; Z,ed<d= Z-ed>d? Z.d@dA Z/edBdC Z0ddEdFZ1ddGdHZ2edIdJ Z3edKdL Z4ddMdNZ5ddOdPZ6edQdR Z7edSdT Z8dUdV Z9dWdX Z:ddYdZZ;dd[d\Z<d]d^ Z=ed_d` Z>dadb Z?ddcddZ@dedf ZAeeBdgdhdi ZCddjdkZDdldm ZEddodpZFddqdrZGddsdtZHddudvZIddwdxZJddydzZKdd{d|ZLd}d~ ZMdd ZNdd ZOedd ZPePj#dd ZPedd ZQeQj#dd ZQedd ZRedd ZSeSj#dd ZSdS )	WorksheetzRepresents a worksheet.

    Do not create worksheets yourself,
    use :func:`openpyxl.workbook.Workbook.create_sheet` instead

    	worksheetz/xl/worksheets/sheet{0}.xmlzIapplication/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xmlr   r      visiblehidden
veryHidden1234567891011portrait	landscapeNc                 C   s   t | || |   d S N)r   __init___setup)selfparenttitle rF   V/var/www/html/api-tag/env/lib/python3.10/site-packages/openpyxl/worksheet/worksheet.pyrA   i   s   zWorksheet.__init__c                 C   s   t | | jd| _t | | jd| _t | _t | _i | _	g | _
g | _t | _d | _g | _t | _t | _g | _t | _g | _d| _t| d| _t | _d | _d | _t | _ t! | _"t# | _$t% | _&t' | _(d| _)t* | _+t, | _-d | _.t/ | _0t1 | _2t3 | _4d S )N)r.   default_factoryr0   )r.   r   )5r   _add_rowrow_dimensions_add_columncolumn_dimensionsr$   
row_breaksr%   
col_breaks_cells_charts_imagesr   _rels_drawing	_commentsr    merged_cellsr'   _tables_pivotsr   data_validations_hyperlinkssheet_stater   
page_setupr   print_options_print_rows_print_colsr,   _print_arear   page_marginsr   viewsr   
protectionr   defined_names_current_rowr   auto_filterr   conditional_formattinglegacy_drawingr#   sheet_propertiesr   sheet_formatr&   	scenariosrC   rF   rF   rG   rB   m   sH   zWorksheet._setupc                 C      | j jS r@   )ra   activerk   rF   rF   rG   
sheet_view      zWorksheet.sheet_viewc                 C      | j jd jS Nr   )rn   	selectionsqrefrk   rF   rF   rG   selected_cell      zWorksheet.selected_cellc                 C   rp   rq   )rn   rr   
activeCellrk   rF   rF   rG   active_cell   ru   zWorksheet.active_cellc                 C   s<   i }| j  D ]}|jdkrt|jtr|jj||j< q|S )zHReturns a dictionary of cells with array formulae and the cells in arrayf)rO   values	data_type
isinstancevaluer(   ref
coordinate)rC   resultcrF   rF   rG   array_formulae   s   
zWorksheet.array_formulaec                 C   rl   r@   )rn   showGridLinesrk   rF   rF   rG   show_gridlines   ro   zWorksheet.show_gridlinesc                 C   s   | j jd ur| j jjS d S r@   )rn   panetopLeftCellrk   rF   rF   rG   freeze_panes   s   
zWorksheet.freeze_panesc                 C   s
  t |tr|j}|dkrd }|sd | j_d S t|\}}| j}t|ddd|_d|jd _|dkr7|d |j_|dkrY|d |j_	d|j_
d|jd _|dkrYd|jd _d|j_
|dkr|dkrt|j}|dtdd d d	 |dtdd d d	 ||_d S d S d S )
NA1topRightfrozen)r   
activePanestater   r   
bottomLeftbottomRight)r   rv   rs   )r{   r   r~   rn   r   r
   r   rr   xSplitySplitr   listinsertr   )rC   r   rowcolumnviewselrF   rF   rG   r      s:   


c                 C   s6   |dk s|dk rt d| ||}|dur||_|S )a  
        Returns a cell object based on the given coordinates.

        Usage: cell(row=15, column=1, value=5)

        Calling `cell` creates cells in memory when they
        are first accessed.

        :param row: row index of the cell (e.g. 4)
        :type row: int

        :param column: column index of the cell (e.g. 3)
        :type column: int

        :param value: value of the cell (e.g. 5)
        :type value: numeric or time or string or bool or none

        :rtype: openpyxl.cell.cell.Cell
        r   z'Row or column values must be at least 1N)
ValueError	_get_cellr|   )rC   r   r   r|   cellrF   rF   rG   r      s   zWorksheet.cellc                 C   sX   d|  k r
dk sn t d| ||f}|| jvr't| ||d}| | | j| S )z
        Internal method for getting a cell from a worksheet.
        Will create a new cell if one doesn't already exist.
        r   i  zCRow numbers must be between 1 and 1048576. Row number supplied was r   r   )r   rO   r   	_add_cell)rC   r   r   r~   r   rF   rF   rG   r      s   


zWorksheet._get_cellc                 C   s,   |j }|j}t|| j| _|| j||f< dS )z:
        Internal method for adding cell objects.
        N)col_idxr   maxrd   rO   )rC   r   r   r   rF   rF   rG   r   	  s   zWorksheet._add_cellc                 C   s  t |trt|j|jgstd|d|j|j}t |tr%t|}t	|\}}}}t
||||gs<td||du rRt| ||}||krP|d }|S |du rlt| j||| j|d}||krj|d }|S d|vrv| ||S t| j||||dS )al  Convenience access by Excel style coordinates

        The key can be a single cell coordinate 'A1', a range of cells 'A1:D25',
        individual rows or columns 'A', 4 or ranges of rows or columns 'A:D',
        4:10.

        Single cells will always be created if they do not exist.

        Returns either a single cell or a tuple of rows or columns.
        z&{0} is not a valid coordinate or rangez{0}:{1}Nr   )min_colmin_rowmax_colmax_row:)r   r   r   r   )r{   sliceallstartstop
IndexErrorformatintstrr	   anytuple	iter_cols	iter_rows
max_columnr   )rC   keyr   r   r   r   colsrowsrF   rF   rG   __getitem__  s4   



zWorksheet.__getitem__c                 C   s   || | _ d S r@   r|   )rC   r   r|   rF   rF   rG   __setitem__<  s   zWorksheet.__setitem__c                 C      |   S r@   r   rk   rF   rF   rG   __iter__@  s   zWorksheet.__iter__c                 C   s.   t |\}}||f| jv r| j||f= d S d S r@   )r
   rO   )rC   r   r   r   rF   rF   rG   __delitem__D  s   zWorksheet.__delitem__c                 C      d}| j rt| j d }|S )zLThe minimum row index containing data (1-based)

        :type: int
        r   r   rO   min)rC   r   rF   rF   rG   r   J     zWorksheet.min_rowc                 C   r   )zLThe maximum row index containing data (1-based)

        :type: int
        r   r   rO   r   )rC   r   rF   rF   rG   r   V  r   zWorksheet.max_rowc                 C   "   d}| j rtdd | j D }|S )zOThe minimum column index containing data (1-based)

        :type: int
        r   c                 s       | ]}|d  V  qdS r   NrF   .0r   rF   rF   rG   	<genexpr>j      z'Worksheet.min_column.<locals>.<genexpr>r   )rC   r   rF   rF   rG   
min_columnb     zWorksheet.min_columnc                 C   r   )zOThe maximum column index containing data (1-based)

        :type: int
        r   c                 s   r   r   rF   r   rF   rF   rG   r   v  r   z'Worksheet.max_column.<locals>.<genexpr>r   )rC   r   rF   rF   rG   r   n  r   zWorksheet.max_columnc           	      C   sz   | j r,t }t }| j D ]\}}|| || qt|}t|}t|}t|}ndS t| | dt| | S )zoReturn the minimum bounding range for all cells containing data (ex. 'A1:M24')

        :rtype: string
        zA1:A1r   )rO   setaddr   r   r   )	rC   r   r   r   colr   r   r   r   rF   rF   rG   calculate_dimensionz  s   

zWorksheet.calculate_dimensionc                 C   r   )z1Returns the result of :func:`calculate_dimension`)r   rk   rF   rF   rG   
dimensions     zWorksheet.dimensionsFc                 C   sX   | j dkrt||||gstdS |pd}|pd}|p| j}|p"| j}| |||||S )a  
        Produces cells from the worksheet, by row. Specify the iteration range
        using indices of rows and columns.

        If no indices are specified the range starts at A1.

        If no cells are in the worksheet an empty tuple will be returned.

        :param min_col: smallest column index (1-based index)
        :type min_col: int

        :param min_row: smallest row index (1-based index)
        :type min_row: int

        :param max_col: largest column index (1-based index)
        :type max_col: int

        :param max_row: largest row index (1-based index)
        :type max_row: int

        :param values_only: whether only cell values should be returned
        :type values_only: bool

        :rtype: generator
        r   rF   r   )rd   r   iterr   r   _cells_by_row)rC   r   r   r   r   values_onlyrF   rF   rG   r     s   

zWorksheet.iter_rowsc                 #   s\    t ||d D ]#  fddt ||d D }|r&tdd |D V  qt|V  qd S )Nr   c                 3   s    | ]
}j  |d V  qdS r   Nr   )r   r   r   rC   rF   rG   r     s    z*Worksheet._cells_by_row.<locals>.<genexpr>c                 s       | ]}|j V  qd S r@   r   r   r   rF   rF   rG   r         ranger   rC   r   r   r   r   r   cellsrF   r   rG   r     s   zWorksheet._cells_by_rowc                 C   r   )zfProduces all cells in the worksheet, by row (see :func:`iter_rows`)

        :type: generator
        r   rk   rF   rF   rG   r     s   zWorksheet.rowsc                 c   s    | j ddD ]}|V  qdS )zTProduces all cell values in the worksheet, by row

        :type: generator
        T)r   Nr   )rC   r   rF   rF   rG   ry     s   zWorksheet.valuesc                 C   sX   | j dkrt||||gstdS |pd}|pd}|p| j}|p"| j}| |||||S )a  
        Produces cells from the worksheet, by column. Specify the iteration range
        using indices of rows and columns.

        If no indices are specified the range starts at A1.

        If no cells are in the worksheet an empty tuple will be returned.

        :param min_col: smallest column index (1-based index)
        :type min_col: int

        :param min_row: smallest row index (1-based index)
        :type min_row: int

        :param max_col: largest column index (1-based index)
        :type max_col: int

        :param max_row: largest row index (1-based index)
        :type max_row: int

        :param values_only: whether only cell values should be returned
        :type values_only: bool

        :rtype: generator
        r   rF   r   )rd   r   r   r   r   _cells_by_col)rC   r   r   r   r   r   rF   rF   rG   r     s   

zWorksheet.iter_colsc                 #   s\    t ||d D ]#  fddt ||d D }|r&tdd |D V  qt|V  qdS )z%
        Get cells by column
        r   c                 3   s    | ]
}j | d V  qdS r   r   )r   r   r   rC   rF   rG   r     s    z*Worksheet._cells_by_col.<locals>.<genexpr>c                 s   r   r@   r   r   rF   rF   rG   r     r   Nr   r   rF   r   rG   r     s   zWorksheet._cells_by_colc                 C   r   )zGProduces all cells in the worksheet, by column  (see :func:`iter_cols`))r   rk   rF   rF   rG   columns  r   zWorksheet.columnsc                 C   s   dd | j  D S )zK
        Return a list of column ranges where more than one column
        c                 S   s$   g | ]}|j r|j|j kr|jqS rF   )r   r   r   )r   cdrF   rF   rG   
<listcomp>  s   $ z+Worksheet.column_groups.<locals>.<listcomp>)rL   ry   rk   rF   rF   rG   column_groups  s   zWorksheet.column_groupsc                 C   s   || j _|| j _dS )zSet printer settings N)r[   	paperSizeorientation)rC   
paper_sizer   rF   rF   rG   set_printer_settings  s   zWorksheet.set_printer_settingsc                 C   s   | j | dS )z Add a data-validation object to the sheet.  The data-validation
            object defines the type of data-validation to be applied and the
            cell or range of cells it should apply to.
        N)rX   append)rC   data_validationrF   rF   rG   add_data_validation   s   zWorksheet.add_data_validationc                 C      |dur||_ | j| dS )zd
        Add a chart to the sheet
        Optionally provide a cell for the top-left anchor
        N)anchorrP   r   )rC   chartr   rF   rF   rG   	add_chart(     zWorksheet.add_chartc                 C   r   )zf
        Add an image to the sheet.
        Optionally provide a cell for the top-left anchor
        N)r   rQ   r   )rC   imgr   rF   rF   rG   	add_image2  r   zWorksheet.add_imagec                 C   s@   | j |jrtd|jt| dstd | j| dS )zr
        Check for duplicate name in definedNames and other worksheet tables
        before adding table.
        z"Table with name {0} already existsr   z6In write-only mode you must add table columns manuallyN)	rD   _duplicate_namenamer   r   hasattrr   rV   r   )rC   tablerF   rF   rG   	add_table<  s
   
zWorksheet.add_tablec                 C   s   | j S r@   )rV   rk   rF   rF   rG   tablesI  s   zWorksheet.tablesc                 C   s   | j | d S r@   )rW   r   )rC   pivotrF   rF   rG   	add_pivotN  s   zWorksheet.add_pivotc                 C   sD   |du rt |||||d}|j}t| |}| j| | | dS )z@ Set merge on a cell range.  Range is a cell range (e.g. A1:E1) Nrange_stringr   r   r   r   )r!   coordr"   rU   r   _clean_merge_range)rC   r   	start_rowstart_columnend_row
end_columncrmcrrF   rF   rG   merge_cellsR  s   
zWorksheet.merge_cellsc                 C   s>   |j }t| |D ]\}}t| ||| j||f< q	|  dS )z
        Remove all but the top left-cell from a range of merged cells
        and recreate the lost border information.
        Borders are then applied
        N)r   nextr   rO   r   )rC   r   r   r   r   rF   rF   rG   r   ]  s
   zWorksheet._clean_merge_rangezUse ws.merged_cells.rangesc                 C   s   | j jdd S )zReturn a copy of cell rangesN)rU   rangesrk   rF   rF   rG   merged_cell_rangesj  s   zWorksheet.merged_cell_rangesc           
      C   sf   t |||||d}|j| jvrtd|j| j| |j}t| |D ]
\}}	| j||	f= q&dS )zC Remove merge on a cell range.  Range is a cell range (e.g. A1:E1) r   zCell range {0} is not mergedN)	r!   r   rU   r   r   remover   r  rO   )
rC   r   r   r   r   r   r   r   r   r   rF   rF   rG   unmerge_cellsq  s   zWorksheet.unmerge_cellsc                 C   s   | j d }t|tttfst|rHt|dD ]0\}}t|tr7|}|jr-|j| kr-t	d| |_||_
||_nt| |||d}|| j||f< qn,t|tro| D ]\}}t|tr^t|}t| |||d}|| j||f< qQn| | || _ dS )a  Appends a group of values at the bottom of the current sheet.

        * If it's a list: all values are added in order, starting from the first column
        * If it's a dict: values are assigned to the columns indicated by the keys (numbers or letters)

        :param iterable: list, range or generator, or dict containing values to append
        :type iterable: list|tuple|range|generator or dict

        Usage:

        * append(['This is A1', 'This is B1', 'This is C1'])
        * **or** append({'A' : 'This is A1', 'C' : 'This is C1'})
        * **or** append({1 : 'This is A1', 3 : 'This is C1'})

        :raise: TypeError when iterable is neither a list/tuple nor a dict

        r   z,Cells cannot be copied from other worksheets)r   r   r|   N)rd   r{   r   r   r   r   	enumerater   rD   r   r   r   rO   dictitemsr   r   _invalid_row)rC   iterablerow_idxr   contentr   rF   rF   rG   r     s0   





zWorksheet.appendr   c                 C   s   |dk}d}d}|dkr| j |d}|}d}	n
| j|d}|}d}	t|}t| jt|	|dD ]\}
}|r:|
|k r:q/|rA||k rAq/| |
||| q/dS )zB
        Move either rows or columns around by the offset
        r   r   )r   )r   r   )r   reverseN)r   r   r   sortedrO   r   
_move_cell)rC   r   r   offset
row_or_colr  
row_offset
col_offsetr   r   r   r   rF   rF   rG   _move_cells  s$   zWorksheet._move_cellsc                 C   s   | j ||dd | j| _dS )z4
        Insert row or rows before row==idx
        r   r   r  r  N)r  r   rd   rC   idxamountrF   rF   rG   insert_rows  s   zWorksheet.insert_rowsc                 C   s   | j ||dd dS )z:
        Insert column or columns before col==idx
        r   r   r  r  N)r  r  rF   rF   rG   insert_cols  s   zWorksheet.insert_colsc                 C   s   t ||| j}| j|| | dd | j}| jd }|D ]}t||D ]}||f| jv r2| j||f= q#q| j| _| js@d| _dS dS )z2
        Delete row or rows from row==idx
        r   r  r   r   N)_gutterr   r  r   r   r   rO   rd   )rC   r  r  	remainderr   r   r   r   rF   rF   rG   delete_rows  s   

zWorksheet.delete_rowsc                 C   sl   t ||| j}| j|| | dd | j}| jd }|D ]}t||D ]}||f| jv r2| j||f= q#qdS )z8
        Delete column or columns from col==idx
        r   r  r   N)r  r   r  r   r   r   rO   )rC   r  r  r  r   r   r   r   rF   rF   rG   delete_cols  s   
zWorksheet.delete_colsc           
      C   s   t |tr	t|}t |tstd|s|sdS |dk}|dk}|r*t|j|d}nt|j|d}t|D ]\}}	| 	||	||| q6|j
||d dS )a  
        Move a cell range by the number of rows and/or columns:
        down if rows > 0 and up if rows < 0
        right if cols > 0 and left if cols < 0
        Existing cells will be overwritten.
        Formulae and references will not be updated.
        z#Only CellRange objects can be movedNr   )r  )	row_shift	col_shift)r{   r   r!   r   r  r   r   r   from_iterabler  shift)
rC   
cell_ranger   r   	translatedownrightr   r   r   rF   rF   rG   
move_range  s   

zWorksheet.move_rangec           
      C   s   |  ||}|j| }|j| }|| j||f< | j|j|jf= ||_||_|r=|jdkr?t|j|j}	|	j||d|_dS dS dS )zn
        Move a cell from one place to another.
        Delete at old index
        Rebase coordinate
        rx   )	row_delta	col_deltaN)	r   r   r   rO   rz   r   r|   r~   translate_formula)
rC   r   r   r  r  r%  r   new_rownew_coltrF   rF   rG   r  !  s   

zWorksheet._move_cellc                 C   s   t dt|)NzQValue must be a list, tuple, range or generator, or a dict. Supplied value is {0})	TypeErrorr   type)rC   r
  rF   rF   rG   r	  3  s   zWorksheet._invalid_rowc                 C      t | S )z(Dimension factory for column information)r   rk   rF   rF   rG   rK   9  r   zWorksheet._add_columnc                 C   r1  )z%Dimension factory for row information)r   rk   rF   rF   rG   rI   >  r   zWorksheet._add_rowc                 C      | j rt| j S dS )z7Rows to be printed at the top of every page (ex: '1:3')N)r]   r   rk   rF   rF   rG   print_title_rowsD     
zWorksheet.print_title_rowsc                 C      |durt || _dS dS )zV
        Set rows to be printed on the top of every page
        format `1:3`
        N)r+   r]   )rC   r   rF   rF   rG   r3  K     c                 C   r2  )z@Columns to be printed at the left side of every page (ex: 'A:C')N)r^   r   rk   rF   rF   rG   print_title_colsU  r4  zWorksheet.print_title_colsc                 C   r5  )zX
        Set cols to be printed on the left of every page
        format ``A:C`
        N)r*   r^   )rC   r   rF   rF   rG   r7  \  r6  c                 C   s   t | j| j| jd}t|S )N)r   r   rE   )r)   r^   r]   rE   r   )rC   titlesrF   rF   rG   print_titlesf  s   zWorksheet.print_titlesc                 C   s   | j | j_ t| jS )z
        The print area for the worksheet, or None if not set. To set, supply a range
        like 'A1:D4' or a list of ranges.
        )rE   r_   r   rk   rF   rF   rG   
print_areal  s   

zWorksheet.print_areac                 C   sN   |st  | _dS t|trt || _dS t|dr%t d|| _dS dS )z
        Range of cells in the form A1:D4 or list of ranges. Print area can be cleared
        by passing `None` or an empty list
        r   ,N)r,   r_   r{   r   from_stringr   join)rC   r|   rF   rF   rG   r:  v  s   

r@   )NNNNF)F)NNNNN)NNr   r   )r   )r   r   F)T__name__
__module____qualname____doc__	_rel_type_path	mime_type
BREAK_NONE	BREAK_ROWBREAK_COLUMNSHEETSTATE_VISIBLESHEETSTATE_HIDDENSHEETSTATE_VERYHIDDENPAPERSIZE_LETTERPAPERSIZE_LETTER_SMALLPAPERSIZE_TABLOIDPAPERSIZE_LEDGERPAPERSIZE_LEGALPAPERSIZE_STATEMENTPAPERSIZE_EXECUTIVEPAPERSIZE_A3PAPERSIZE_A4PAPERSIZE_A4_SMALLPAPERSIZE_A5ORIENTATION_PORTRAITORIENTATION_LANDSCAPErA   rB   propertyrn   rt   rw   r   r   r   setterr   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   ry   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	  rK   rI   r3  r7  r9  r:  rF   rF   rF   rG   r-   D   s    
&







#
)






'	


	
&









0







	

	

	r-   c                 C   s*   t t|d | | t| | |d }|S )z
    When deleting rows and columns are deleted we rely on overwriting.
    This may not be the case for a large offset on small set of cells:
    range(cells_to_delete) > range(cell_to_be_moved)
    r   )r   r   r   )r  r  max_valgutterrF   rF   rG   r    s   &r  N)GrA  	itertoolsr   operatorr   inspectr   warningsr   openpyxl.compatr   openpyxl.utilsr   r   r	   r
   openpyxl.cellr   r   openpyxl.formatting.formattingr   openpyxl.packaging.relationshipr   openpyxl.workbook.childr   openpyxl.workbook.defined_namer   openpyxl.formula.translater   datavalidationr   pager   r   r   r   r   r   r   r   rb   r   filtersr   ra   r   r   r   r$  r    r!   merger"   
propertiesr#   	pagebreakr$   r%   scenarior&   r   r'   formular(   print_settingsr)   r*   r+   r,   r-   r  rF   rF   rF   rG   <module>   sF         F