Class UniprotProxySequenceReader<C extends Compound>
java.lang.Object
org.biojava.nbio.core.sequence.loader.UniprotProxySequenceReader<C>
- Type Parameters:
C
-
- All Implemented Interfaces:
Iterable<C>
,DatabaseReferenceInterface
,FeaturesKeyWordInterface
,Accessioned
,ProxySequenceReader<C>
,Sequence<C>
,SequenceReader<C>
public class UniprotProxySequenceReader<C extends Compound>
extends Object
implements ProxySequenceReader<C>, FeaturesKeyWordInterface, DatabaseReferenceInterface
Pass in a Uniprot ID and this ProxySequenceReader when passed to a ProteinSequence will get the sequence data and other data elements
associated with the ProteinSequence by Uniprot. This is an example of how to map external databases of proteins and features to the BioJava3
ProteinSequence.
Important to call @see setUniprotDirectoryCache to allow caching of XML files so they don't need to be reloaded each time. Does
not manage cache.
-
Field Summary
-
Constructor Summary
ConstructorDescriptionUniprotProxySequenceReader
(String accession, CompoundSet<C> compoundSet) The UniProt id is used to retrieve the UniProt XML which is then parsed as a DOM object so we know everything about the protein.UniprotProxySequenceReader
(Document document, CompoundSet<C> compoundSet) The xml is passed in as a DOM object so we know everything about the protein. -
Method Summary
Modifier and TypeMethodDescriptionint
countCompounds
(C... compounds) Returns the number of times we found a compound in the Sequenceboolean
Returns the AccessionID this location is currently bound withPull uniprot accessions associated with this sequencePull uniprot protein aliases associated with this sequence Provided for backwards compatibility now that we support both gene and protein aliases via separate methods.Returns the Sequence as a List of compoundsgetCompoundAt
(int position) Returns the Compound at the given biological indexGets the compound set used to back this SequenceThe Uniprot mappings to other database identifiers for this sequencePull uniprot gene aliases associated with this sequenceGet the gene name associated with this sequence.int
getIndexOf
(C compound) Scans through the Sequence looking for the first occurrence of the given compoundDoes the right thing to get the inverse of the current Sequence.Pull UniProt key words which is a mixed bag of words associated with this sequenceint
getLastIndexOf
(C compound) Scans through the Sequence looking for the last occurrence of the given compoundint
The sequence lengthGet the organism name assigned to this sequencePull uniprot protein aliases associated with this sequenceReturns the String representation of the SequencegetSequenceAsString
(Integer bioBegin, Integer bioEnd, Strand strand) getSubSequence
(Integer bioBegin, Integer bioEnd) Returns a portion of the sequence from the different positions.static String
The current UniProt URL to deal with caching issues. www.uniprot.org is load balanced but you can access pir.uniprot.org directly.static String
Local directory cache of XML that can be downloadedint
hashCode()
iterator()
static <C extends Compound>
UniprotProxySequenceReader<C> parseUniprotXMLString
(String xml, CompoundSet<C> compoundSet) The passed in xml is parsed as a DOM object so we know everything about the protein.void
setCompoundSet
(CompoundSet<C> compoundSet) void
setContents
(String sequence) Once the sequence is retrieved set the contents and make sure everything this is valid Some uniprot records contain white space in the sequence.static void
setUniprotbaseURL
(String aUniprotbaseURL) static void
setUniprotDirectoryCache
(String aUniprotDirectoryCache) toString()
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
Methods inherited from interface java.lang.Iterable
forEach, spliterator
-
Field Details
-
UP_AC_PATTERN
-
DEFAULT_UNIPROT_BASE_URL
- See Also:
-
-
Constructor Details
-
UniprotProxySequenceReader
public UniprotProxySequenceReader(String accession, CompoundSet<C> compoundSet) throws CompoundNotFoundException, IOException The UniProt id is used to retrieve the UniProt XML which is then parsed as a DOM object so we know everything about the protein. If an error occurs throw an exception. We could have a bad uniprot id or network error- Parameters:
accession
-compoundSet
-- Throws:
CompoundNotFoundException
IOException
- if problems while reading the UniProt XML
-
UniprotProxySequenceReader
public UniprotProxySequenceReader(Document document, CompoundSet<C> compoundSet) throws CompoundNotFoundException The xml is passed in as a DOM object so we know everything about the protein. If an error occurs throw an exception. We could have a bad uniprot id- Parameters:
document
-compoundSet
-- Throws:
CompoundNotFoundException
-
-
Method Details
-
parseUniprotXMLString
public static <C extends Compound> UniprotProxySequenceReader<C> parseUniprotXMLString(String xml, CompoundSet<C> compoundSet) The passed in xml is parsed as a DOM object so we know everything about the protein. If an error occurs throw an exception. We could have a bad uniprot id- Parameters:
xml
-compoundSet
-- Returns:
- UniprotProxySequenceReader
-
setCompoundSet
- Specified by:
setCompoundSet
in interfaceSequenceReader<C extends Compound>
-
setContents
Once the sequence is retrieved set the contents and make sure everything this is valid Some uniprot records contain white space in the sequence. We must strip it out so setContents doesn't fail.- Specified by:
setContents
in interfaceSequenceReader<C extends Compound>
- Parameters:
sequence
-- Throws:
CompoundNotFoundException
-
getLength
The sequence length -
getCompoundAt
Description copied from interface:Sequence
Returns the Compound at the given biological index- Specified by:
getCompoundAt
in interfaceSequence<C extends Compound>
- Parameters:
position
-- Returns:
-
getIndexOf
Description copied from interface:Sequence
Scans through the Sequence looking for the first occurrence of the given compound- Specified by:
getIndexOf
in interfaceSequence<C extends Compound>
- Parameters:
compound
-- Returns:
-
getLastIndexOf
Description copied from interface:Sequence
Scans through the Sequence looking for the last occurrence of the given compound- Specified by:
getLastIndexOf
in interfaceSequence<C extends Compound>
- Parameters:
compound
-- Returns:
-
toString
-
getSequenceAsString
Description copied from interface:Sequence
Returns the String representation of the Sequence- Specified by:
getSequenceAsString
in interfaceSequence<C extends Compound>
- Returns:
-
getAsList
Description copied from interface:Sequence
Returns the Sequence as a List of compounds -
equals
-
hashCode
-
getInverse
Description copied from interface:Sequence
Does the right thing to get the inverse of the current Sequence. This means either reversing the Sequence and optionally complementing the Sequence.- Specified by:
getInverse
in interfaceSequence<C extends Compound>
- Returns:
-
getSequenceAsString
- Parameters:
bioBegin
-bioEnd
-strand
-- Returns:
-
getSubSequence
Description copied from interface:Sequence
Returns a portion of the sequence from the different positions. This is indexed from 1- Specified by:
getSubSequence
in interfaceSequence<C extends Compound>
- Parameters:
bioBegin
-bioEnd
-- Returns:
-
iterator
-
getCompoundSet
Description copied from interface:Sequence
Gets the compound set used to back this Sequence- Specified by:
getCompoundSet
in interfaceSequence<C extends Compound>
- Returns:
-
getAccession
Description copied from interface:Accessioned
Returns the AccessionID this location is currently bound with- Specified by:
getAccession
in interfaceAccessioned
- Returns:
-
getAccessions
Pull uniprot accessions associated with this sequence- Returns:
- Throws:
XPathExpressionException
-
getAliases
Pull uniprot protein aliases associated with this sequence Provided for backwards compatibility now that we support both gene and protein aliases via separate methods.- Returns:
- Throws:
XPathExpressionException
-
getProteinAliases
Pull uniprot protein aliases associated with this sequence- Returns:
- Throws:
XPathExpressionException
-
getGeneAliases
Pull uniprot gene aliases associated with this sequence- Returns:
- Throws:
XPathExpressionException
-
countCompounds
Description copied from interface:Sequence
Returns the number of times we found a compound in the Sequence- Specified by:
countCompounds
in interfaceSequence<C extends Compound>
- Parameters:
compounds
-- Returns:
-
getUniprotbaseURL
The current UniProt URL to deal with caching issues. www.uniprot.org is load balanced but you can access pir.uniprot.org directly.- Returns:
- the uniprotbaseURL
-
setUniprotbaseURL
- Parameters:
aUniprotbaseURL
- the uniprotbaseURL to set
-
getUniprotDirectoryCache
Local directory cache of XML that can be downloaded- Returns:
- the uniprotDirectoryCache
-
setUniprotDirectoryCache
- Parameters:
aUniprotDirectoryCache
- the uniprotDirectoryCache to set
-
getGeneName
Get the gene name associated with this sequence.- Returns:
-
getOrganismName
Get the organism name assigned to this sequence- Returns:
-
getKeyWords
Pull UniProt key words which is a mixed bag of words associated with this sequence- Specified by:
getKeyWords
in interfaceFeaturesKeyWordInterface
- Returns:
-
getDatabaseReferences
The Uniprot mappings to other database identifiers for this sequence- Specified by:
getDatabaseReferences
in interfaceDatabaseReferenceInterface
- Returns:
-