Skip to main content

No project description provided

Project description

Introduction

A package to read/write xlsx worksheet like dictionary, based on openpyxl.

Installation

  • from pip
pip install pyxlsx
  • download package and run setup.py
python setup.py install

Usage

  • Create a new xlsx file and write to it
from pyxlsx import new_xlsx

with new_xlsx(filename) as wb:
    ws = wb.create_sheet('sheet1')
    # some operations

# or
wb = new_xlsx()
ws = wb.creat_sheet('sheet1')  # create a new sheet with name 'sheet1'
# some operations
wb.save(filename)
  • Open an existing xlsx file
from pyxlsx import open_xlsx

with open_xlsx(filename) as wb:
    ws1 = wb.active  # get active sheet
    ws2 = wb['sheet2']
    # some operations

# or
wb = open_xlsx(filename)
ws = wb['sheet2']
# some operations
wb.save()
# to save as another file
wb.save(another_filename)
  • Append rows to a worksheet
ws = wb['sheet1']
ws.append(
    ["", "", "str('Unknown')", "float(4.5)", "int(500)", "str()"]
)
# keys can only be of type str
content1 = {
    'id': '001',
    'productName': 'pork',
    'productType': 'meat',
    'price': 2.5,
    'weight': 1000,
}
content2 = {
    'id': '002',
    'productName': 'beef',
    'productType': 'meat',
    'price': 4.5,
    'weight': 1000,
    'origin': 'Australia'
}
# header is auto-generated from keys of the dict the first time append_by_header is called.
ws.append_by_header(content1)  
# new header name will be append to header if append_header is True (default value)
ws.append_by_header(content2)  
# below is the result of writing operation
A B C D E F
1 str('Unknown') float(30) int(0) str()
2 id productName productType price weight origin
3 001 pork meat 2.5 1000
4 002 beef meat 4.5 1000 Australia
  • Read from / write to a worksheet by row Note: if there are duplicate header names, only the first would be used.
ws = wb['sheet1']
assert ws.header is None
ws.header_row = 2  # set the second row as worksheet header row
assert ws.header is not None

for row in ws.content_rows:  # starting from row just below header row
    print(row[1])  # row cell value can accessed by column number, if key is of type int
    print(row['productName'])  # row cell value can be accessed by header name, if key is of type of str
    print(row['price'])  
    if row['productName'] == 'pork':
        row[1] = '003'  # change pork id to '003'
        row['price'] = 3.5  # change pork price to 3.5
# output as below
# '001'
# 'pork'
# 2.5
# '002'
# 'beef'
# 4.5
  • Read from a worksheet by column
ws = wb['sheet1']
ws.header_row = 2
# get a full column
column_cells = ws['B']
for c in column_cells:
    print(c.data)  # 'pork', 'beef'

# get a content column (containing only cells below header) by header name, 
# if key is of type str
name_column = ws.get_content_column('productName')
for c in name_column:
    print(c.data)  # 'pork', 'beef'

# get a content column by column number,
# if key is of type int
name_column = ws.get_content_column(2)
for c in name_column:
    print(c.data)  # 'pork', 'beef'
  • Read cell directly from Worksheet, Header, ContentRow
ws = wb['sheet1']
ws.header_row = 2
# access a cell by coordinate (row, column)
cell = ws.cell(2, 2)
print(cell.data)  # 'productName'

# access a cell by header name if key is of type str
cell = ws.header.cell('productName')
print(cell.data)  # 'productName'
# access a cell by column number
cell = ws.header.cell(1)
print(cell.data)  # 'id'

for row in ws.content_rows:
    cell = row.cell(1)  # '001', '002'
    print(cell.data)
    cell = row.cell('productName')
    print(cell.data)  # 'pork', 'beef'
  • Read adjacent cells of a certain cell
cell = ws.cell(2, 2)
print(cell.top.data)  # "str('Unknown')"
print(cell.left.data)  # 'id'
print(cell.right.data)  # 'productType'
print(cell.bottom.data)  # 'pork'

for c in cell.vertical:
    print(c.data)  # 'productName', 'pork', 'beef'

for c in cell.horizontal:
    print(c.data)  # 'productName', 'productType', 'price', 'weigth', 'origin'

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyxlsx-1.0.tar.gz (12.5 kB view details)

Uploaded Source

Built Distributions

pyxlsx-1.0-py3.7.egg (31.0 kB view details)

Uploaded Source

pyxlsx-1.0-py3-none-any.whl (13.6 kB view details)

Uploaded Python 3

File details

Details for the file pyxlsx-1.0.tar.gz.

File metadata

  • Download URL: pyxlsx-1.0.tar.gz
  • Upload date:
  • Size: 12.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/46.0.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.7

File hashes

Hashes for pyxlsx-1.0.tar.gz
Algorithm Hash digest
SHA256 a2f0b83aac45b52ee712a35a6ca808633dfc953f7b4e25fe50f272e0981400b4
MD5 c62736d1ad77f54a8218973dfcf5429b
BLAKE2b-256 2586cd271a85eb485f694f95d190dd8bd01c4e10cd2c3d38c924283d72d677e9

See more details on using hashes here.

File details

Details for the file pyxlsx-1.0-py3.7.egg.

File metadata

  • Download URL: pyxlsx-1.0-py3.7.egg
  • Upload date:
  • Size: 31.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/46.0.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.7

File hashes

Hashes for pyxlsx-1.0-py3.7.egg
Algorithm Hash digest
SHA256 519466c0faea855b0bf1f117047e7cdfdf33706959a956a1e62ed02c3926e73b
MD5 a30598fef31d3a01401d0a711c398ec6
BLAKE2b-256 19ba44941d32b3b05c712cfc1a92731b117eca188fa6d1b075fe807d4d1621aa

See more details on using hashes here.

File details

Details for the file pyxlsx-1.0-py3-none-any.whl.

File metadata

  • Download URL: pyxlsx-1.0-py3-none-any.whl
  • Upload date:
  • Size: 13.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/46.0.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.7

File hashes

Hashes for pyxlsx-1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ef93e84eb7aa0e1c826e8e02c3eafdc1c6a784abe9aefeda5a8678f6f7356518
MD5 be0db44d5b9fc838866fd444e562fcbb
BLAKE2b-256 b3972efa0f44a08388f269f026e1d0bea94f5ee1ba26b909a461413c1a24b904

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page