a
    f=_                     @   sp  d dl mZ d dlZddlmZmZmZ ddlT ddlT ddl	T zd dl
mZ W n eyn   d dl
mZ Y n0 d dlmZ ejZd Zd dlZd	Zed
\ZZZZZdZdddddddddddddddZi Zi Ze D ](\ZZe eZe eZeee< eee< q[[[de!j"d dddddddf
ddZ#G dd  d e$Z%G d!d" d"e$Z&d#d$ Z'd,d&d'Z(d(d) Z)d*d+ Z*dS )-    )print_functionN   )compdoc
formattingsheet)*)perf_counter)clockunpacki    )P   F   2   -   (             	
)ZConsolidate_AreaZ	Auto_OpenZ
Auto_CloseZExtractZDatabaseZCriteriaZ
Print_AreaZPrint_TitlesZRecorderZ	Data_FormZAuto_ActivateZAuto_DeactivateZSheet_TitleZ_FilterDatabaseTFc
                 C   s^  t  }
t }z&|j| |||||||||	d
 t  }||
 |_|t}|sTtd|tvrltdt|  ||_	|dkr|rt
|jd d |_}|  nR|dkr|  |rt
|jd d |_}n&|  dd	 |jD |_|s|  t|j|_|dkr"|jd
kr"t
|jd|j t  }|| |_W n   |   Y n0 |sZ|  |S )N)
filenamefile_contentslogfile	verbosityuse_mmapencoding_overrideformatting_info	on_demandragged_rowsignore_workbook_corruptionz#Can't determine file's BIFF versionz BIFF version %s is not supportedr   z`*** WARNING: on_demand is not supported for this Excel version.
*** Setting on_demand to False.
Fr   c                 S   s   g | ]}d qS N ).0shr.   r.   (lib/python3.9/site-packages/xlrd/book.py
<listcomp>i       z%open_workbook_xls.<locals>.<listcomp>r   z|*** WARNING: Excel 4.0 workbook (.XLW) file contains %d worksheets.
*** Book-level data will be that of the last worksheet.
)r   Bookbiff2_8_loadload_time_stage_1getbofXL_WORKBOOK_GLOBALS	XLRDErrorSUPPORTED_VERSIONSZbiff_text_from_numbiff_versionfprintfr%   r*   fake_globals_get_sheetparse_globals_sheet_names_sheet_list
get_sheetslennsheetsload_time_stage_2release_resources)r#   r%   r&   r'   r$   r(   r)   r*   r+   r,   t0Zbkt1r;   t2r.   r.   r1   open_workbook_xls;   sn    	



rI   c                   @   sd   e Zd ZdZdgZdZdZdZdZdZ	dZ
dZdZdZdZedZdZdZdZdd	 ZdddZdS )Namez
    Information relating to a named reference, formula, macro, etc.

    .. note::

      Name information is **not** extracted from files older than
      Excel 5.0 (``Book.biff_version < 50``)
    stackNr    r3   c                 C   s   | j }|r|j}|j}|tkrt|dkr|d }d|j  krN|jd krn n>|j|jd kr|j	|j
d kr| j|j}||j|j	S | j| jjddd tddS )a:  
        This is a convenience method for the frequent use case where the name
        refers to a single cell.

        :returns: An instance of the :class:`~xlrd.sheet.Cell` class.

        :raises xlrd.biffh.XLRDError:
          The name is not a constant absolute reference
          to a single cell.
        r   r   === Dump of Name object ========== End of dump =======headerZfooterz2Not a constant absolute reference to a single cellN)resultkindvalueoREFrB   shtxloshtxhirowxlorowxhicolxlocolxhibooksheet_by_indexcelldumpr%   r9   )selfresrS   rT   ref3dr0   r.   r.   r1   r^      s&     z	Name.cellTc                 C   sF  | j }|r&|j}|j}|tkr&t|dkr&|d }d|j  krV|jd kr&n n| j|j}|s||j	|j
|j|jfS t|j	|j}t|t|j
|j}t|j|j}	t|	t|j|j}
d|  kr|  kr|jksn J d|	  kr|
  kr|jksn J ||||	|
fS | j| jjddd tddS )a  
        This is a convenience method for the use case where the name
        refers to one rectangular area in one worksheet.

        :param clipped:
          If ``True``, the default, the returned rectangle is clipped
          to fit in ``(0, sheet.nrows, 0, sheet.ncols)``.
          it is guaranteed that ``0 <= rowxlo <= rowxhi <= sheet.nrows`` and
          that the number of usable rows in the area (which may be zero) is
          ``rowxhi - rowxlo``; likewise for columns.

        :returns: a tuple ``(sheet_object, rowxlo, rowxhi, colxlo, colxhi)``.

        :raises xlrd.biffh.XLRDError:
           The name is not a constant absolute reference
           to a single area in a single sheet.
        r   r   rN   rO   rP   zDNot a constant absolute reference to a single area in a single sheetN)rR   rS   rT   rU   rB   rV   rW   r\   r]   rX   rY   rZ   r[   minZnrowsmaxZncolsr_   r%   r9   )r`   Zclippedra   rS   rT   rb   r0   rX   rY   rZ   r[   r.   r.   r1   area2d   s.    "&,zName.area2d)T)__name__
__module____qualname____doc__Z_repr_theser\   hiddenfuncvbasicmacrocomplexbuiltin	funcgroupbinary
name_indexUNICODE_LITERALnameraw_formulascoperR   r^   re   r.   r.   r.   r1   rJ      s$   
rJ   c                
   @   s  e Zd ZdZdZdZdZg ZdZdZ	dZ
edZg Zg Zg Zi Zi Zi Zg ZdZ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 i Z!i Z"dd Z#dde$j%dddd d d d f
d!d"Z&d#d$ Z'd%d& Z(d'd( Z)d)d* Z*dYd+d,Z+d-d. Z,d/d0 Z-d1d2 Z.d3d4 Z/d5d6 Z0d7d8 Z1d9d: Z2d;d< Z3d=d> Z4d?d@ Z5dAdB Z6dCdD Z7dEdF Z8dGdH Z9dIdJ Z:dKdL Z;dMdN Z<dOdP Z=dQdR Z>dSdT Z?dUdV Z@dWdX ZAdS )Zr4   z
    Contents of a "workbook".

    .. warning::

      You should not instantiate this class yourself. You use the :class:`Book`
      object that was returned when you called :func:`~xlrd.open_workbook`.
    r   Nr   r   rL   g      c                 C   s2   t | jD ]}| j| s
| | q
| jdd S )zt
        :returns: A list of all sheets in the book.

        All sheets not already loaded will be loaded.
        N)xrangerC   r@   	get_sheetr`   sheetxr.   r.   r1   sheets  s    
zBook.sheetsc                 C   s   | j | p| |S )zr
        :param sheetx: Sheet index in ``range(nsheets)``
        :returns: A :class:`~xlrd.sheet.Sheet`.
        )r@   ry   rz   r.   r.   r1   r]     s    zBook.sheet_by_indexc                 c   s    t | jD ]}| |V  q
dS )z
        Makes iteration through sheets of a book a little more straightforward.
        Don't free resources after use since it can be called like `list(book)`
        N)rangerC   r]   )r`   ir.   r.   r1   __iter__  s    zBook.__iter__c                 C   s:   z| j |}W n ty.   td| Y n0 | |S )zp
        :param sheet_name: Name of the sheet required.
        :returns: A :class:`~xlrd.sheet.Sheet`.
        No sheet named <%r>)r?   index
ValueErrorr9   r]   )r`   
sheet_namer{   r.   r.   r1   sheet_by_name  s
    zBook.sheet_by_namec                 C   s"   t |tr| |S | |S dS )z
        Allow indexing with sheet name or index.
        :param item: Name or index of sheet enquired upon
        :return: :class:`~xlrd.sheet.Sheet`.
        N)
isinstanceintr]   r   )r`   itemr.   r.   r1   __getitem__  s    

zBook.__getitem__c                 C   s   | j dd S )z
        :returns:
          A list of the names of all the worksheets in the workbook file.
          This information is available even when no sheets have yet been
          loaded.
        N)r?   r`   r.   r.   r1   sheet_names  s    zBook.sheet_namesc                 C   sN   t |tr|}n0z| j|}W n ty>   td| Y n0 t| j| S )z
        :param sheet_name_or_index: Name or index of sheet enquired upon
        :returns: ``True`` if sheet is loaded, ``False`` otherwise.

        .. versionadded:: 0.7.1
        r   )r   r   r?   r   r   r9   boolr@   r`   Zsheet_name_or_indexr{   r.   r.   r1   sheet_loaded  s    
zBook.sheet_loadedc                 C   sN   t |tr|}n0z| j|}W n ty>   td| Y n0 d| j|< dS )zu
        :param sheet_name_or_index: Name or index of sheet to be unloaded.

        .. versionadded:: 0.7.1
        r   N)r   r   r?   r   r   r9   r@   r   r.   r.   r1   unload_sheet  s    
zBook.unload_sheetc                 C   sN   d| _ t| jdr| j  d| _t| jdr8| j  d| _d| _d| _dS )a_  
        This method has a dual purpose. You can call it to release
        memory-consuming objects and (possibly) a memory-mapped file
        (:class:`mmap.mmap` object) when you have finished loading sheets in
        ``on_demand`` mode, but still require the :class:`Book` object to
        examine the loaded sheets. It is also called automatically (a) when
        :func:`~xlrd.open_workbook`
        raises an exception and (b) if you are using a ``with`` statement, when
        the ``with`` block is exited. Calling this method multiple times on the
        same object has no ill effect.
        r   closeN)_resources_releasedhasattrmemr   filestr_sharedstrings_rich_text_runlist_mapr   r.   r.   r1   rE   
  s    

zBook.release_resourcesc                 C   s   | S r-   r.   r   r.   r.   r1   	__enter__!  s    zBook.__enter__c                 C   s   |    d S r-   )rE   )r`   exc_type	exc_valueZexc_tbr.   r.   r1   __exit__$  s    zBook.__exit__c                 C   s   g | _ g | _g | _d| _g | _g | _i | _d| _d| _d| _	| 
  d| _d| _d | _d | _g | _g | _g | _i | _i | _d| _g | _d| _g | _g | _i | _g | _g | _i | _d| _d| _d S )Nr   FrM   r3   )r@   r?   _sheet_visibilityrC   _sh_abs_posnr   r   raw_user_name_sheethdr_countbuiltinfmtcountinitialise_format_info_all_sheets_count_supbook_count_supbook_locals_inx_supbook_addins_inx_all_sheets_map_externsheet_info_externsheet_type_b57_extnsht_name_from_num_sheet_num_from_name_extnsht_count_supbook_typesr   addin_func_namesname_obj_list
colour_mappalette_recordxf_liststyle_name_mapr   r   r   r.   r.   r1   __init__5  s>    zBook.__init__TFc                 C   s  || _ || _|| _|| _|| _|| _|	| _|st|d|}|dd |	 }|dd |dkrjt
d| jrtj| |tjd| _|| _n| | _t| j| _W d    q1 s0    Y  n|| _t|| _d| _| jd d tjkr| j| _n~tj| j| j |
d}dD ].}|t|\| _| _| _| jr qJqt
d	~| j| jurxt| jd
rr| j  d| _| j| _trtdt| j| j| jf | j d d S )Nrbr      zFile size is 0 bytes)access   )r%   r,   )ZWorkbookr4   z-Can't find workbook in OLE2 compound documentr   r3   zmem: %s, base: %d, len: %dfile)r%   r&   r'   r(   r)   r*   r+   openseektellr9   mmapfilenoZACCESS_READr   Z
stream_lenreadrB   baser   Z	SIGNATUREr   ZCompDocZlocate_named_streamrs   r   r   	_positionDEBUGprinttype)r`   r#   r$   r%   r&   r'   r(   r)   r*   r+   r,   fsizeZcdZqnamer.   r.   r1   r5   V  sR    	
,



zBook.biff2_8_loadc                 C   s8   i | _ g | _d| _d| _dti| _d| _g | _g | _d S )Nr   )	
format_mapformat_listZxfcountZactualfmtcountZXL_CELL_NUMBERZ_xf_index_to_xl_type_map_xf_epilogue_doner   	font_listr   r.   r.   r1   r     s    
zBook.initialise_format_infoc                 C   sV   | j }| j||d  }t|}|  j |7  _ |dk r:tS |\}}t|d> t|B S )Nr   r   )r   r   rB   MY_EOF	BYTES_ORD)r`   posZbuff_twoZlenbufflohir.   r.   r1   	get2bytes  s    zBook.get2bytesc                 C   sR   | j }| j}td|||d  \}}|d7 }||||  }|| | _ |||fS )N<HH   r   r   r   )r`   r   r   codelengthdatar.   r.   r1   get_record_parts  s    
zBook.get_record_partsc                 C   s^   | j }| j}td|||d  \}}||kr2dS |d7 }||||  }|| | _ |||fS )Nr   r   )Nr   r3   r   )r`   Zreqd_recordr   r   r   r   r   r.   r.   r1   get_record_parts_conditional  s    
z!Book.get_record_parts_conditionalc                 C   sX   | j rtd|r| j| | _| t t| | j| j| |}|	|  || j
|< |S )Nz,Can't load sheets after releasing resources.)r   r9   r   r   r7   XL_WORKSHEETr   ZSheetr?   r   r@   )r`   Z	sh_number
update_posr0   r.   r.   r1   ry     s    


zBook.get_sheetc                 C   sX   t rtd| j| j| jd tt| jD ]*}t rHtd|| j| j| jd | | q(d S )NzGET_SHEETS:r   zGET_SHEETS: sheetno =)r   r   r?   r   r%   rx   rB   ry   )r`   sheetnor.   r.   r1   rA     s    zBook.get_sheetsc                 C   sB   t |  td}|g| _dg| _dg| _| jd  |   d S )NzSheet 1r   )	r   initialise_bookrs   r?   r   r   r@   appendrA   )r`   Zfake_sheet_namer.   r.   r1   r=     s    
zBook.fake_globals_get_sheetc           
      C   s~  | j }|   tr"t| jd|| |dkrft|d| jdd}d}t}t| j	dkr`| j
| j }qd}nLtd|dd \}}}|| j }|tk rt|d| jdd}nt|ddd}ts| jd	krt| jd
| j|||| |  jd7  _|tkr6| jd dddd|d}ts"| jdkrzt| jd||| nDt| j}	| j|	 | j| | j	| | j| |	| j|< d S )NzBOUNDSHEET: bv=%d data %r
r   r   r   ZlenlenrM   z<iBB   r   zFBOUNDSHEET: inx=%d vis=%r sheet_name=%r abs_posn=%d sheet_type=0x%02x
zMacro sheetZChartzVisual Basic module)r   r   r   ZUNKNOWNzANOTE *** Ignoring non-worksheet data named %r (type 0x%02x = %s)
)r;   derive_encodingr   r<   r%   unpack_stringencodingZXL_BOUNDSHEET_WORKSHEETrB   r   _sheetsoffsetr   r   ZBIFF_FIRST_UNICODEunpack_unicoder&   r   r   r   getr?   r   r   )
r`   r   bvr   Z
visibilityZ
sheet_typeZabs_posnoffsetZdescrZsnumr.   r.   r1   handle_boundsheet  sR    


zBook.handle_boundsheetc                 C   s2   t d|dd d }tr(t| jd| || _d S )N<Hr   r   zBUILTINFMTCOUNT: %r
)r   r   r<   r%   r   )r`   r   r   r.   r.   r1   handle_builtinfmtcount  s    zBook.handle_builtinfmtcountc                 C   s  | j r| j | _n| jd u rV| jdk r8t| jd d| _qd| _| jdkrt| jd n| j}|tv rnt| }nHd|  krdkrn nd	t| }n"| jdkrd| _d
}ndt| }t	s| jr|| jkrt| jd|| || _| jdkrNzt
d| j W nP tyL } z6t| jd| j| jt|jdd |  W Y d }~n
d }~0 0 | jr~t| jd| jdd}| }|| _d| _| jS )Nr   zD*** No CODEPAGE record, no encoding_override: will use 'iso-8859-1'
z
iso-8859-1i  r   z2*** No CODEPAGE record; assuming 1200 (utf_16_le)
i,  i  Zcp	utf_16_leZunknown_codepage_z%CODEPAGE: codepage %r -> encoding %r
s   trialz/ERROR *** codepage %r -> encoding %r -> %s: %s
.rM   r   r   r   F)r(   r   codepager;   r<   r%   r&   Zencoding_from_codepagestrr   unicodeBaseExceptionr   rf   splitr   r   	user_namerstrip)r`   r   r   estrgr.   r.   r1   r     sL    





zBook.derive_encodingc                 C   s(   t d|dd d }|| _|   d S )Nr   r   r   )r   r   r   )r`   r   r   r.   r.   r1   handle_codepageE  s    zBook.handle_codepagec                 C   sJ   t d|dd }| jr(td|| jd | jdks@| j|ks@J || _d S )Nr   r   r   z
Countries:r   rw   )r   r&   r   r%   	countries)r`   r   r   r.   r.   r1   handle_countryK  s    zBook.handle_countryc                 C   sD   t d|dd d }ts | jr.t| jd| |dv s:J || _d S )Nr   r   r   zDATEMODE: datemode %r
)r   r   )r   r   r&   r<   r%   datemode)r`   r   r   r.   r.   r1   handle_datemodeR  s
    
zBook.handle_datemodec                 C   s   t p| jdk}| jdkrtd|d d \}}d}t||dd\}}||d  }| jd tkrj| j| |rt	| j
d| jd |||| d S )	Nr   r   <HIr   r   r   rM   zCEXTERNNAME: sbktype=%d oflags=0x%04x oinfo=0x%08x name=%r extra=%r
)r   r&   r;   r   unpack_unicode_update_posr   SUPBOOK_ADDINr   r   r<   r%   )r`   r   blahoption_flagsZ
other_infor   rt   Zextrar.   r.   r1   handle_externnameY  s    
zBook.handle_externnamec                 C   s  |    |  jd7  _tp"| jdk}tp0| jdk}| jdkrtd|dd d }|d d }t||k r|rt| jd|t| | 	 \}}}|t
krtd||7 }q`d}	t|D ]P}
td	||	|	d  }|\}}}| j| |	d7 }	|rt| jd
|
||| qntd|d d \}}|rztd| jd t|dt|| jd ddddd|d}td|||f | jd |dkrt|d|d  | j}|| j| j< |rt| j| jd d|  krdksn d}| j| d S )Nr   r   r   r   r   r   z*INFO: EXTERNSHEET needs %d bytes, have %d
z)Missing CONTINUE after EXTERNSHEET recordz<HHHzLEXTERNSHEET(b8): k = %2d, record = %2d, first_sheet = %5d, last sheet = %5d
z<BBzEXTERNSHEET(b7-):r   foutzEncoded URLzCurrent sheet!!zSpecific sheet in own doc'tz Nonspecific sheet in own doc't!!)r   r      r   zNot encodedz   %3d chars, type is %d (%s)r  r   )r   r   r   r&   r;   r   rB   r<   r%   r   XL_CONTINUEr9   rx   r   r   r   hex_char_dumpr   r   r   r   r   )r`   r   Zblah1Zblah2Znum_refsZ
bytes_reqdcode2Zlength2Zdata2r   kinfoZref_recordxZref_first_sheetxZref_last_sheetxZnctymsgr   r.   r.   r1   handle_externsheetg  sb    


zBook.handle_externsheetc                 C   s   | j dkr| j}t|d t|dt|d|d | jdkrtd|d d \}|dkr|td|dd  \}}t|d|| nH|d	krtd|d
d \}|d	krd}n|dkrd}nd}t|d| tdd S )Nr   z
FILEPASS:
r   )r   r   r   r   r   z!weak XOR: key=0x%04x hash=0x%04x
r   r   r   z	BIFF8 stdzBIFF8 strongz** UNKNOWN ENCRYPTION METHOD **z%s
zWorkbook is encrypted)r&   r%   r<   r  rB   r;   r   r9   )r`   r   ZlogfZkind1keyZ
hash_valueZkind2Zcaptionr.   r.   r1   handle_filepass  s*    


zBook.handle_filepassc                 C   s  t p| jdk}| j}|dk r d S |   td|dd \
}}}}}}	}
}}}t }| |_t| j}||_	| j
| ||_g d}|D ]\}}}t||||@ |?  qd|j }|dk rt|d| j|d	\}}nt|d|d	\}}||_|	|_d |_|rt| jd
|||||||	|
 |}|jrHt|d}|rHtd| | jd ||_||d  |_||_d|_|r|j| jd| dd d S )Nr   r   z	<HBBHHH4Br      ))rj   r   r   )rk   r   r   )rl   r   r   )rm   r   r  )rn      r   )ro       r   )rp   i  r   )rq   i      z Mr   )Z	known_lenzZNAME[%d]:%s oflags=%d, name_len=%d, fmla_len=%d, extsht_index=%d, sheet_index=%d, name=%r
z??Unknown??z    builtin: %sr   z--- handle_name: name[%d] ---z-------------------rP   )r   r&   r;   r   r   rJ   r\   rB   r   rr   r   r   setattrrm   Zunpack_string_update_posr   r   extn_sheet_numexcel_sheet_indexrv   r<   r%   ro   builtin_name_from_coder   r   rt   ru   Zbasic_formula_len	evaluatedr_   )r`   r   r   r   r   Zkb_shortcutZname_lenZfmla_lenZextsht_indexsheet_indexZmenu_text_lenZdescription_text_lenZhelp_topic_text_lenZstatus_bar_text_lennobjrr   attrsattrmaskZnshiftZ
macro_flagZinternal_namer   rt   r.   r.   r1   handle_name  s\    


zBook.handle_namec                 C   s  | j dk}| j}|r\td|d tdt| j|d tdt| j|d tdt| j|d t| j}t	|D ]}| j| }| j
dkr|j}|dkrd	}n>d
|  krt| jkrn n| j|d
  }|d	krd}nd}nJd| j
  krdkr$n n.|j}|dkrd	}n| j| }| j|d}||_qnt	|D ]@}| j| }|js4|jrVq4|jrbq4t| |||d q4| j dkrtd|d t	|D ]"}| j| }|j|d| d qtd|d i }	i }
t	|D ]z}| j| }|j }||jf}||	v r| j rt|d| ||	|< |j||f}||
v rD|
| | n
|g|
|< q|
 D ](}|
| }|  dd |D |
|< qZ|	| _|
| _d S )Nr   z+++++ names_epilogue +++++r   r   r   r   r   r   rM   r   r   r   )r   z&---------- name object dump ----------z--- name[%d] ---)rQ   z&--------------------------------------z)Duplicate entry %r in name_and_scope_map
c                 S   s   g | ]}|d  qS )r   r.   )r/   xr.   r.   r1   r2   3  r3   z'Book.names_epilogue.<locals>.<listcomp>)r&   r%   r   ZREPRr   r   r   rB   r   r}   r;   r  r  r   rv   rm   rq   r  Zevaluate_name_formular_   rt   lowerr<   r   keyssortname_and_scope_mapname_map)r`   r   r   Z	num_namesZnamexr  r  Zintl_sheet_indexr   r!  r"  Z
name_lcaser
  Z	sort_dataZalistr.   r.   r1   names_epilogue  sp    











zBook.names_epiloguec                 C   s   t d|dd \}}d S )Nr   r   
   r
   )r`   r   Zobj_typeZobj_idr.   r.   r1   
handle_obj7  s    zBook.handle_objc           
   	   C   s  | j d  tp| jdk}|rBtd| jd t|dt|| jd td|dd d }|rntd| | jd | j	}|  j	d7  _	|dd	 d
krt
| j d< | j	d | _|rtd||f | jd td| j| jd d S |dd	 dkrt| j d< | j	d | _|rtd| | jd d S t|ddd\}}|dkr\t| j d< |rXt| jd|| d S t| j d< |r|t| jd|| g }t|D ]}zt||dd\}	}W n> tjy   | jrtd|||f | jd Y  qY n0 ||	 |rt| jd|t|	|	| qd S )Nr   zSUPBOOK:r   r   r   r   znum_sheets = %dr   r   s   rM   z(SUPBOOK[%d]: internal 3D refs; %d sheetsz    _all_sheets_maps    :zSUPBOOK[%d]: add-in functionsr   z#SUPBOOK[%d]: DDE/OLE document = %r
zSUPBOOK[%d]: url = %r
zK*** WARNING: unpack failure in sheet %d of %d in SUPBOOK record for file %rz-  sheetx=%d namelen=%d name=%r (next pos=%d)
)r   r   r   r&   r   r%   r  rB   r   r   SUPBOOK_INTERNALr   r   r   r   r   SUPBOOK_DDEOLEr<   SUPBOOK_EXTERNALr}   structerror)
r`   r   r   Z
num_sheetsZsbnurlr   r   r  Zshnamer.   r.   r1   handle_supbook>  sV    





zBook.handle_supbookc                 C   s   |    td|d d d }t|d| jdd}| j}|| j| ksHJ |  jd7  _| j}|d t| }trt	| j
d|||| |   trtd| j | j
d | jd  | j|d	d
 trtd| j| j
d || | _d S )N<ir   r   r   r   z'SHEETHDR %d at posn %d: len=%d name=%r
z SHEETHDR: xf epilogue flag is %dr   F)r   z"SHEETHDR: posn after get_sheet() =)r   r   r   r   r   r?   r   rB   r   r<   r%   r   r   r   r@   r   ry   )r`   r   Z	sheet_lenr   r   ZBOF_posnposnr.   r.   r1   handle_sheethdrm  s    zBook.handle_sheethdrc                 C   s,   t d|d }tr"td|| jd || _d S )Nr-  r   zSHEETSOFFSET:r   )r   r   r   r%   r   )r`   r   r.  r.   r.   r1   handle_sheetsoffset  s    zBook.handle_sheetsoffsetc           
      C   s   t rtd| jd t }t|}|g}td|dd d }t sJ| jdkrXt| jd| | t	\}}}|d u rrq||7 }t dkrt| jd	|| |
| qXt||\| _}| jr|| _t rt }	td
|	| f | jd d S )NzSST Processingr   r-  r   r   r   r   zSST: unique strings: %d
z'CONTINUE: adding %d bytes to SST -> %d
z SST processing took %.2f seconds)r   r   r%   r   rB   r   r&   r<   r   r  r   unpack_SST_tabler   r)   r   )
r`   r   rF   ZnbtZstrlistZuniquestringsr   nbZ
rt_runlistrG   r.   r.   r1   
handle_sst  s*    zBook.handle_sstc                 C   s   d}| j dk r8| js$d| _|| _d S t|d| jdd}n8zt|ddd}W n$ tyn   t| ddd}Y n0 |rt| j	dt
|| j| | }|| _d S )Nr   r   Tr   r   r   z!WRITEACCESS: %d bytes; raw=%s %r
)r;   r   r   r   r   r   UnicodeDecodeErrorstripr<   r%   rB   r   )r`   r   r   r   r.   r.   r1   handle_writeaccess  s    
zBook.handle_writeaccessc                 C   sD  t |  |  \}}}tr.td| | jd |tkrB| | q
|tksR|t	kr^| 
| q
|tkrr| | q
|tkr| | q
|tkr| | q
|tkr| | q
|tkr| | q
|tkr| | q
|tkr| | q
|tkr | | q
|tkr| | q
|tkr,| | q
|tkrB|  | q
|t!krX| "| q
|t#krn| $| q
|t%kr| &| q
|t'kr| (| q
|t)kr| *| q
|d@ dkr| j+rt,| jd| j-| d ||| q
|t.kr
| /  | 0  | 1  | j2s| 3  | j4dkr:tr:td| j-| jd d S q
d S )	Nz$parse_globals: record code is 0x%04xr      	   z5*** Unexpected BOF at posn %d: 0x%04x len=%d data=%r
r   r   zglobal EOF: position)5r   r   r   r   r   r%   ZXL_SSTr3  ZXL_FONTZXL_FONT_B3B4Zhandle_fontZ	XL_FORMATZhandle_formatZXL_XFZ	handle_xfZXL_BOUNDSHEETr   ZXL_DATEMODEr   ZXL_CODEPAGEr   Z
XL_COUNTRYr   ZXL_EXTERNNAMEr   ZXL_EXTERNSHEETr	  ZXL_FILEPASSr  ZXL_WRITEACCESSr6  ZXL_SHEETSOFFSETr0  ZXL_SHEETHDRr/  Z
XL_SUPBOOKr,  ZXL_NAMEr  Z
XL_PALETTEZhandle_paletteZXL_STYLEZhandle_styler&   r<   r   ZXL_EOFZxf_epiloguer#  Zpalette_epiloguer   r   r;   )r`   rcr   r   r.   r.   r1   r>     sj    









zBook.parse_globalsc                 C   s$   | j |||  }|t| | _|S r-   )r   rB   r   )r`   r   r   r   r.   r.   r1   r     s    z	Book.readc                 C   s  t rtd| | jd dd }| j}|  }|tkr<|d |tvr^|d| j||d    |  }|tkrv|d d	|  krd
ksn |d||f  dtdt	| |  }| 
| j|}t rt| jd| t||k r|d ||7 }|d? }td|dd	 \}	}
t r*td||	|
f | jd | jd	 | }t rTtd||f | jd d } }}|dkrtd|d	d \}}|	dkrd}nB|	dkr|dk s|dv rd}nd}ndddddd|	d}n|dv rdddd| }|dkr|
tkrd}t s| jd kr6td!||	|
|||f | jd |
tkpP|dkoP|
tk}|tkrb|sl|
|krp|S |dk r|
tkr|S |dkr|
d"kr|d# |d$||	|
|||f  d S )%Nzreqd: 0x%04xr   c                 S   s   t d|  d S )Nz%Unsupported format, or corrupt file: )r9   )r  r.   r.   r1   	bof_error  s    zBook.getbof.<locals>.bof_errorz$Expected BOF record; met end of filezExpected BOF record; found %rr   z)Incomplete BOF record[1]; met end of filer   r   z.Invalid length (%d) for BOF record type 0x%04x    r   z
getbof(): data=%r
z)Incomplete BOF record[2]; met end of filer   z5getbof(): op=0x%04x version2=0x%04x streamtype=0x%04xz+getbof(): BOF found at offset %d; savpos=%di   r   i   i  )il	  i  i  r   r   r   r   r   )r      i   i   i   )r   r   r   r   r   zHBOF: op=0x%04x vers=0x%04x stream=0x%04x buildid=%d buildyr=%d -> BIFF%d   z%Workspace file -- no spreadsheet datazXBOF not workbook/worksheet: op=0x%04x vers=0x%04x strm=0x%04x build=%d year=%d -> BIFF%d)r   r   r%   r   r   r   Zbofcodesr   rd   Zboflenr   r<   rB   r   r   ZXL_WORKBOOK_GLOBALS_4Wr&   r8   r   )r`   Z
rqd_streamr:  ZsavposZopcoder   Zpaddingr   Zversion1Zversion2Z
streamtypeZ
bof_offsetversionZbuildZyearZgot_globalsr.   r.   r1   r7     s    




zBook.getbof)T)Brf   rg   rh   ri   rC   r   r;   r   r   r   r   rs   r   r   r   r   r   r   r   r   r6   rD   r|   r]   r   r   r   r   r   r   rE   r   r   r!  r"  r   sysstdoutr5   r   r   r   r   ry   rA   r=   r   r   r   r   r   r   r   r	  r  r  r#  r%  r,  r/  r0  r3  r6  r>   r   r7   r.   r.   r.   r1   r4     s   	!
9
	
	4-3<J/@r4   c                 C   s\   | }|d@ r"|dkr|d8 }d}nd}|d@ }|d@ rL|dkrF|d8 }d}nd}||||fS )	Ni   i   r   r   r7  i @     r=  r.   )ZinrowZincolZoutrowrelrowZoutcolrelcolr.   r.   r1   expand_cell_addressF  s    rD  ABCDEFGHIJKLMNOPQRSTUVWXYZc                 C   sD   | dksJ t d}t| d\}}|| | }|s6|S |d } qd S )Nr   rL      r   )rs   divmod)colxZ_A2Zrt   ZquotZremr.   r.   r1   colnameX  s    rI  c                 C   s^   |rdd| dk  t | f }nd| d f }|rJdd|dk  t |f }ndt| }|| S )Nz(*%s%d)z+-r   z$%dr   $)absrI  )ZrowxrH  rB  rC  ZrowpartZcolpartr.   r.   r1   display_cell_addressb  s    rL  c              
   C   s  d}t | }| d }t |}d}g }|j}i }	t}
t}t}d}t|D ]F}|
d|||d  d }|d7 }||| }|d7 }d}d}|d@ r|
d|||d  d }|d7 }|d@ r|
d|||d  d }|d7 }td	}d}|| }|d@ rR||| d? |}|||d|   }z|t|d
7 }W n    Y n0 |d| 7 }n4||| |}||||  }|t||7 }||7 }||7 }||krq|d7 }| | }t |}||d }d}q|r6g }t|D ]P}||krd}|d7 }| | }t |}||
d|||d   |d7 }q||	t |< ||7 }||kr|| }|d7 }||k rt| | }t |}n||d ksJ || qF||	fS )zReturn list of stringsr   r   latin_1r   r   r   r   r-  rL   r   r   )rB   r   r   rc   r   rx   rs   r   )ZdatatabZnstringsZdatainxZndatasr   Zdatalenr   stringsZ	strappendZrichtext_runsZlocal_unpackZ	local_minZlocal_BYTES_ORDrM  Z	_unused_iZncharsoptionsZrtcountZphoszZaccstrgZcharsgotZ	charsneedZ
charsavailZrawstrgrunsZrunindexr.   r.   r1   r1  m  s    






r1  )rE  )+Z
__future__r   r)  rL   r   r   r   ZbiffhZformulaZtimemachinetimer   ImportErrorr	   r   Z
empty_cellr   r   r   r}   ZSUPBOOK_UNKr&  r(  r   r'  r:   Z_code_from_builtin_namer  Zcode_from_builtin_nameitemsZ_binZ_bicrs   r?  r@  rI   Z
BaseObjectrJ   r4   rD  rI  rL  r1  r.   r.   r.   r1   <module>   sz   

D         @

