U
    7h[                  	   @   s2  d dl Z d dlZd dlZd dlZddl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 ddlmZmZ ddlT ddlmZmZ ddlmZ dd	lmZmZmZ dd
lmZ ej !drd dl"Z"zd dl#Z#dZ$W n e%k
r   d Z$Y nX e$Z&dej'd e&dddddf	ddZ(ej'dfddZ)ej'fddZ*dS )    N   )timemachine)
XL_CELL_BLANKXL_CELL_BOOLEANXL_CELL_DATEXL_CELL_EMPTYXL_CELL_ERRORXL_CELL_NUMBERXL_CELL_TEXT	XLRDErrorbiff_text_from_numerror_text_from_code)Bookcolname)*)__VERSION____version__)
empty_cell)XLDateErrorxldate_as_datetimexldate_as_tuple)X12Book
IronPythonFc	                 C   s   d}	|r|d|	 }
n,t j| } t| d}||	}
W 5 Q R X |
dkr|r`tt|}n
t| }t	dd |
 D }|r|d t|| d|krd	d
lm} |j||||||||d}|S d|krtdd|krtdtdd	dlm} |j| ||||||||d	}|S )a  
    Open a spreadsheet file for data extraction.

    :param filename: The path to the spreadsheet file to be opened.

    :param logfile: An open file to which messages and diagnostics are written.

    :param verbosity: Increases the volume of trace material written to the
                      logfile.

    :param use_mmap:

      Whether to use the mmap module is determined heuristically.
      Use this arg to override the result.

      Current heuristic: mmap is used if it exists.

    :param file_contents:

      A string or an :class:`mmap.mmap` object or some other behave-alike
      object. If ``file_contents`` is supplied, ``filename`` will not be used,
      except (possibly) in messages.

    :param encoding_override:

      Used to overcome missing or bad codepage information
      in older-version files. See :doc:`unicode`.

    :param formatting_info:

      The default is ``False``, which saves memory.
      In this case, "Blank" cells, which are those with their own formatting
      information but no data, are treated as empty by ignoring the file's
      ``BLANK`` and ``MULBLANK`` records.
      This cuts off any bottom or right "margin" of rows of empty or blank
      cells.
      Only :meth:`~xlrd.sheet.Sheet.cell_value` and
      :meth:`~xlrd.sheet.Sheet.cell_type` are available.

      When ``True``, formatting information will be read from the spreadsheet
      file. This provides all cells, including empty and blank cells.
      Formatting information is available for each cell.

      Note that this will raise a NotImplementedError when used with an
      xlsx file.

    :param on_demand:

      Governs whether sheets are all loaded initially or when demanded
      by the caller. See :doc:`on_demand`.

    :param ragged_rows:

      The default of ``False`` means all rows are padded out with empty cells so
      that all rows have the same size as found in
      :attr:`~xlrd.sheet.Sheet.ncols`.

      ``True`` means that there are no empty cells at the ends of rows.
      This can result in substantial memory savings if rows are of widely
      varying sizes. See also the :meth:`~xlrd.sheet.Sheet.row_len` method.

    :returns: An instance of the :class:`~xlrd.book.Book` class.
       Nrbs   PKc                 S   s   g | ]}t ||fqS  )r   Zconvert_filename).0namer   r   G/var/www/formularioweb/env/lib/python3.8/site-packages/xlrd/__init__.py
<listcomp>z   s   z!open_workbook.<locals>.<listcomp>zZIP component_names:
zxl/workbook.xmlr   )xlsx)logfile	verbosityuse_mmapformatting_info	on_demandragged_rowszxl/workbook.binz#Excel 2007 xlsb file; not supportedzcontent.xmlz&Openoffice.org ODS file; not supportedz.ZIP file contents not a known type of workbook)book)	filenamer!   r"   r#   file_contentsencoding_overrider$   r%   r&   )ospath
expanduseropenreadzipfileZipFiler   ZBYTES_IOdictnamelistwritepprint r    Zopen_workbook_2007_xmlr   r'   Zopen_workbook_xls)r(   r!   r"   r#   r)   r*   r$   r%   r&   ZpeekszpeekfzfZcomponent_namesr    bkr'   r   r   r   open_workbook!   s^    I


r;   c                 C   s<   ddl m} t }|j| |d ||j|j|jd|| dS )a  
    For debugging: dump an XLS file's BIFF records in char & hex.

    :param filename: The path to the file to be dumped.
    :param outfile: An open file, to which the dump is written.
    :param unnumbered: If true, omit offsets (for meaningful diffs).
    r   )	biff_dumpr(   r!   r   N)biffhr<   r   biff2_8_loadmembase
stream_len)r(   outfileZ
unnumberedr<   r:   r   r   r   dump   s    rD   c                 C   s8   ddl m} t }|j| |d ||j|j|j| dS )a  
    For debugging and analysis: summarise the file's BIFF records.
    ie: produce a sorted file of ``(record_name, count)``.

    :param filename: The path to the file to be summarised.
    :param outfile: An open file, to which the summary is written.
    r   )biff_count_recordsr=   N)r>   rE   r   r?   r@   rA   rB   )r(   rC   rE   r:   r   r   r   count_records   s    rF   )+r+   r5   sysr0   r6   r   r>   r   r   r   r   r   r	   r
   r   r   r   r'   r   r   Zformulainfor   r   Zsheetr   Zxldater   r   r   r    r   version
startswith	encodingsmmapZMMAP_AVAILABLEImportErrorZUSE_MMAPstdoutr;   rD   rF   r   r   r   r   <module>   s@   0

 