45981495d1
1 June 2021: Biopython 1.79 ================================ This is intended to be our final release supporting Python 3.6. It also supports Python 3.7, 3.8 and 3.9, and has also been tested on PyPy3.6.1 v7.1.1. The ``Seq`` and ``MutableSeq`` classes in ``Bio.Seq`` now store their sequence contents as ``bytes` ` and ``bytearray`` objects, respectively. Previously, for ``Seq`` objects a string object was used, and a Unicode array object for ``MutableSeq`` objects. This was maintained during the transition from Python2 to Python3. However, a Python2 string object corresponds to a ``bytes`` object in Python3, storing the string as a series of 256-bit characters. While non- ASCII characters could be stored in Python2 strings, they were not treated as such. For example: In Python2:: >>> s = "Генетика" >>> type(s) <class 'str'> >>> len(s) 16 In Python3:: >>> s = "Генетика" >>> type(s) <class 'str'> >>> len(s) 8 In Python3, storing the sequence contents as ``bytes`` and ``bytearray`` objects has the further advantage that both support the buffer protocol. Taking advantage of the similarity between ``bytes`` and ``bytearray``, the ``Seq`` and ``MutableSeq`` classes now inherit from an abstract base class ``_SeqAbstractBaseClass`` in ``Bio.Seq`` that implements most of the ``Seq`` and ``MutableSeq`` methods, ensuring their consistency with each other. For methods that modify the sequence contents, an optional ``inplace`` argument to specify if a new sequence object should be returned with the new sequence contents (if ``inplace`` is ``False``, the default) or if the sequence object itself should be modified (if ``inplace`` is ``True``). For ``Seq`` objects, which are immutable, using ``inplace=True`` raises an exception. For ``inplace=False``, the default, ``Seq`` objects and ``MutableSeq`` behave consistently. As before, ``Seq`` and ``MutableSeq`` objects can be initialized using a string object, which will be converted to a ``bytes`` or ``bytearray`` object assuming an ASCII encoding. Alternatively, a ``bytes`` or ``bytearray`` object can be used, or an instance of any class inheriting from the new ``SequenceDataAbstractBaseClass`` abstract base class in ``Bio.Seq``. This requires that the class implements the ``__len__`` and ``__getitem`` methods that return the sequence length and sequence contents on demand. Initialzing a ``Seq`` instance using an instance of a class inheriting from ``SequenceDataAbstractBaseClass`` allows the ``Seq`` object to be lazy, meaning that its sequence is provided on demand only, without requiring to initialize the full sequence. This feature is now used in ``BioSQL``, providing on-demand sequence loading from an SQL database, as well as in a new parser for twoBit (.2bit) sequence data added to ``Bio.SeqIO``. This is a lazy parser that allows fast access to genome-size DNA sequence files by not having to read the full genome sequence. The new ``_UndefinedSequenceData`` class in ``Bio.Seq`` also inherits from ``SequenceDataAbstractBaseClass`` to represent sequences of known length but unknown sequence contents. This provides an alternative to ``UnknownSeq``, which is now deprecated as its definition was ambiguous. For example, in these examples the ``UnknownSeq`` is interpreted as a sequence with a well-defined sequence contents:: >>> s = UnknownSeq(3, character="A") >>> s.translate() UnknownSeq(1, character='K') >>> s + "A" Seq("AAAA") A sequence object with an undefined sequence contents can now be created by using ``None`` when creating the ``Seq`` object, together with the sequence length. Trying to access its sequence contents raises an ``UndefinedSequenceError``:: >>> s = Seq(None, length=6) >>> s Seq(None, length=6) >>> len(s) 6 >>> "A" in s Traceback (most recent call last): ... Bio.Seq.UndefinedSequenceError: Sequence content is undefined >>> print(s) Traceback (most recent call last): .... Bio.Seq.UndefinedSequenceError: Sequence content is undefined Element assignment in Bio.PDB.Atom now returns "X" when the element cannot be unambiguously guessed from the atom name, in accordance with PDB structures. Bio.PDB entities now have a ``center_of_mass()`` method that calculates either centers of gravity or geometry. New method ``disordered_remove()`` implemented in Bio.PDB DisorderedAtom and DisorderedResidue to remove children. New module Bio.PDB.SASA implements the Shrake-Rupley algorithm to calculate atomic solvent accessible areas without third-party tools. Expected ``TypeError`` behaviour has been restored to the ``Seq`` object's string like methods (fixing a regression in Biopython 1.78). The KEGG ``KGML_Pathway`` KGML output was fixed to produce output that complies with KGML v0.7.2. Parsing motifs in ``pfm-four-rows`` format can now handle motifs with values in scientific notation. Parsing motifs in ``minimal``` MEME format will use ``nsites`` when making the count matrix from the frequency matrix, instead of multiply the frequency matrix by 1000000. Bio.UniProt.GOA now parses Gene Product Information (GPI) files version 1.2, files can be downloaded from the EBI ftp site: ftp://ftp.ebi.ac.uk/pub/databases/GO/goa/ 4 September 2020: Biopython 1.78 ================================ This release of Biopython supports Python 3.6, 3.7 and 3.8. It has also been tested on PyPy3.6.1 v7.1.1. The main change is that ``Bio.Alphabet`` is no longer used. In some cases you will now have to specify expected letters, molecule type (DNA, RNA, protein), or gap character explicitly. Please consult the updated Tutorial and API documentation for guidance. This simplification has sped up many ``Seq`` object methods. See https://biopython.org/wiki/Alphabet for more information. ``Bio.SeqIO.parse()`` is faster with "fastq" format due to small improvements in the ``Bio.SeqIO.QualityIO`` module. The ``SeqFeature`` object's ``.extract()`` method can now be used for trans-spliced locations via an optional dictionary of references. As in recent releases, more of our code is now explicitly available under either our original "Biopython License Agreement", or the very similar but more commonly used "3-Clause BSD License". See the ``LICENSE.rst`` file for more details. Additionally, a number of small bugs and typos have been fixed with additions to the test suite. There has been further work to follow the Python PEP8, PEP257 and best practice standard coding style, and all of the tests have been reformatted with the ``black`` tool to match the main code base. 25 May 2020: Biopython 1.77 =========================== This release of Biopython supports Python 3.6, 3.7 and 3.8 It has also been tested on PyPy3.6.1 v7.1.1-beta0. **We have dropped support for Python 2 now.** ``pairwise2`` now allows the input of parameters with keywords and returns the alignments as a list of ``namedtuples``. The codon tables have been updated to NCBI genetic code table version 4.5, which adds Cephalodiscidae mitochondrial as table 33. Updated ``Bio.Restriction`` to the January 2020 release of REBASE. A major contribution by Rob Miller to ``Bio.PDB`` provides new methods to handle protein structure transformations using dihedral angles (internal coordinates). The new framework supports lossless interconversion between internal and cartesian coordinates, which, among other uses, simplifies the analysis and manipulation of coordinates of proteins structures. As in recent releases, more of our code is now explicitly available under either our original "Biopython License Agreement", or the very similar but more commonly used "3-Clause BSD License". See the ``LICENSE.rst`` file for more details. Additionally, a number of small bugs and typos have been fixed with further additions to the test suite. There has been further work to follow the Python PEP8, PEP257 and best practice standard coding style, and all the main code base has been reformatted with the ``black`` tool. 20 December 2019: Biopython 1.76 ================================ This release of Biopython supports Python 2.7, 3.5, 3.6, 3.7 and 3.8. It has also been tested on PyPy2.7.13 v7.1.1 and PyPy3.6.1 v7.1.1-beta0. We intend this to be our final release supporting Python 2.7 and 3.5. As in recent releases, more of our code is now explicitly available under either our original "Biopython License Agreement", or the very similar but more commonly used "3-Clause BSD License". See the ``LICENSE.rst`` file for more details. ``PDBParser`` and ``PDBIO`` now support PQR format file parsing and input/ output. In addition to the mainstream ``x86_64`` aka ``AMD64`` CPU architecture, we now also test every contribution on the ``ARM64``, ``ppc64le``, and ``s390x`` CPUs under Linux thanks to Travis CI. Further post-release testing done by Debian and other packagers and distributors of Biopython also covers these CPUs. ``Bio.motifs.PositionSpecificScoringMatrix.search()`` method has been re-written: it now applies ``.calculate()`` to chunks of the sequence to maintain a low memory footprint for long sequences. Additionally, a number of small bugs and typos have been fixed with further additions to the test suite. There has been further work to follow the Python PEP8, PEP257 and best practice standard coding style, and more of the code style has been reformatted with the ``black`` tool. 6 November 2019: Biopython 1.75 =============================== This release of Biopython supports Python 2.7, 3.5, 3.6, 3.7 and is expected to work on the soon to be released Python 3.8. It has also been tested on PyPy2.7.13 v7.1.1 and PyPy3.6.1 v7.1.1-beta0. Note we intend to drop Python 2.7 support in early 2020. The restriction enzyme list in ``Bio.Restriction`` has been updated to the August 2019 release of REBASE. ``Bio.SeqIO`` now supports reading and writing files in the native format of Christian Marck's DNA Strider program ("xdna" format, also used by Serial Cloner), as well as reading files in the native formats of GSL Biotech's SnapGene ("snapgene") and Textco Biosoftware's Gene Construction Kit ("gck"). ``Bio.AlignIO`` now supports GCG MSF multiple sequence alignments as the "msf" format (work funded by the National Marrow Donor Program). The main ``Seq`` object now has string-like ``.index()`` and ``.rindex()`` methods, matching the existing ``.find()`` and ``.rfind()`` implementations. The ``MutableSeq`` object retains its more list-like ``.index()`` behaviour. The ``MMTFIO`` class has been added that allows writing of MMTF file format files from a Biopython structure object. ``MMTFIO`` has a similar interface to ``PDBIO`` and ``MMCIFIO``, including the use of a ``Select`` class to write out a specified selection. This final addition to read/write support for PDB/mmCIF/MMTF in Biopython allows conversion between all three file formats. Values from mmCIF files are now read in as a list even when they consist of a single value. This change improves consistency and reduces the likelihood of making an error, but will require user code to be updated accordingly. `Bio.motifs.meme` has been updated to parse XML output files from MEME over the plain-text output file. The goal of this change is to parse a more structured data source with minimal loss of functionality upon future MEME releases. ``Bio.PDB`` has been updated to support parsing REMARK 99 header entries from PDB-style Astral files. A new keyword parameter ``full_sequences`` was added to ``Bio.pairwise2``'s pretty print method ``format_alignment`` to restore the output of local alignments to the 'old' format (showing the whole sequences including the un-aligned parts instead of only showing the aligned parts). A new function ``charge_at_pH(pH)`` has been added to ``ProtParam`` and ``IsoelectricPoint`` in ``Bio.SeqUtils``. The ``PairwiseAligner`` in ``Bio.Align`` was extended to allow generalized pairwise alignments, i.e. alignments of any Python object, for example three-letter amino acid sequences, three-nucleotide codons, and arrays of integers. A new module ``substitution_matrices`` was added to ``Bio.Align``, which includes an ``Array`` class that can be used as a substitution matrix. As the ``Array`` class is a subclass of a numpy array, mathematical operations can be applied to it directly, and C code that makes use of substitution matrices can directly access the numerical values stored in the substitution matrices. This module is intended as a replacement of ``Bio.SubsMat``, which is currently unmaintained. As in recent releases, more of our code is now explicitly available under either our original "Biopython License Agreement", or the very similar but more commonly used "3-Clause BSD License". See the ``LICENSE.rst`` file for more details. Additionally, a number of small bugs and typos have been fixed with further additions to the test suite, and there has been further work to follow the Python PEP8, PEP257 and best practice standard coding style. We have also started to use the ``black`` Python code formatting tool. |
||
---|---|---|
.. | ||
DESCR | ||
distinfo | ||
Makefile | ||
PLIST |