<p align="center">
<img src="https://raw.githubusercontent.com/luanrabelo/SyBA/stable/docs/assets/SyBA.png" alt="SyBA Logo" width="25%">
</p>
# Contents Overview
- [System Overview](#system-overview)
- [Getting Started with SyBA](#getting-started-with-syba)
- [Prerequisites](#prerequisites)
- [Installation Guide](#installation-guide)
- [Efficiency of SyBA](#efficiency-of-syba)
- [SyBA Class Functions](#syba-class-functions)
- [init](#syba-init)
- [SyBA Update](#syba-update)
- [SyBA fixName](#syba-fixname)
- [SyBA buildQuery](#syba-buildquery)
- [Example Codes](#example-codes)
- [Web Form for SyBA](#web-form-for-syba)
- [License Information](#license-information)
- [Development Team](#development-team)
- [Citing SyBA](#citing-syba)
***
# System Overview
##### [Go to Contents Overview](#contents-overview)
SyBA (**Sy**nonymous of **BA**cterial Genes) is a **tool** and **database** for **standardizing gene names in bacterial genomes**. It provides a consistent nomenclature for gene names, allowing researchers to accurately search for genes from bacteria that cause **human diseases**, improving **public health** research on **foodborne illnesses** (Figure 1).
> ![MarineGEO circle logo](https://raw.githubusercontent.com/luanrabelo/SyBA/stable/assets/img/Figure1.png "Map") Figure 1. Global snapshot of the Food Contamination Monitoring and Assessment Programme, highlighting the top 10 countries and various regions. The data is sourced from the Global Environment Monitoring System, avaliable at https://apps.who.int/foscollab/Download/DownloadConta
The **SyBA** database is constructed using gene symbols and gene products (proteins) present in **1,215,109 functional bacterial genomes**, based on the genera _Campylobacter_, _Clostridium_, _Escherichia_, _Listeria_, _Salmonella_, _Shigella_, _Staphylococcus_, and _Vibrio_.
**SyBA** includes a **Python class** for standardizing gene names, which can automatically find and change different name variations into a standard form. The class also generates search commands for specific genes or papers in **GenBank** or **PubMedCentral** with different bacterial gene names.
Additionally, **SyBA** provides a **web form** that is **easy-to-use** for **researchers** to **search for specific genes or papers** in **GenBank** or **PubMedCentral**.
The **SyBA** repository, hosted on **GitHub** and **licensed under MIT**, is a **freely accessible** resource for the **scientific community**. It offers comprehensive analysis results of bacterial gene names. In addition, it includes thorough **guidelines and sample scripts** to **assist researchers in their work**.
***
# Getting Started with **SyBA**
##### [Go to Contents Overview](#contents-overview)
- ## Prerequisites
Before you run **SyBA**, make sure you have the following prerequisites installed on your system:
- **Python Environment**
- Python **version 3.6 or higher**
- conda (optional)
- Dependencies (these will be automatically installed with pip)
- `requests`
- `pandas`
- `openpyxl`
- `numpy`
- ## Installation Guide
There are **tree** ways to install **SyBA**:
1. **Through pip**: Install **SyBA** directly using pip:
```bash
pip install SyBA
```
- This will install **SyBA** and its **dependencies** in your **Python environment**.
2. **By cloning the GitHub repository**: Clone the source code of **SyBA** from GitHub:
```bash
git clone https://github.com/luanrabelo/SyBA.git
cd SyBA
pip install -r requirements.txt
```
- This command will **clone the repository**, and then you should **navigate to the cloned directory** to **install SyBA and its dependencies** using pip.
3. Installation via **conda**: You can also install **SyBA** using conda with the following commands:
```bash
conda create -n SyBA -c conda-forge -c bioconda SyBA
conda activate SyBA
```
- This method will set up **SyBA** along with its **dependencies** in a **new conda environment**.
***
# Efficiency of SyBA
##### [Go to Contents Overview](#contents-overview)
> ![SyBA](https://raw.githubusercontent.com/luanrabelo/SyBA/stable/assets/img/Figure2.png "Comparison") Figure 2. **(a)** Comparison between the number of gene name variations in the **SyBA database (v1.0.0)** and the number of proteins without a gene name. **(b)** The **15 genes** with the **most name variations** in the **SyBA database (v1.0.0)**. **(c)** By applying the names of proteins that do **not have a gene name**, it is possible to **recover this information** in up to **55.3%** of cases. **(d)** The **time required** for the **SyBA class** to **standardize gene names** in **1000 bacterial genomes**, with the **possibility of executing the function asynchronously** to further **reduce processing time**. **(e)** The time required to **generate 1000 search commands** with gene name variations.
> ![SyBA](https://raw.githubusercontent.com/luanrabelo/SyBA/stable/assets/img/Figure3.png "Comparison") Figure 3. A comparative analysis of search results in **March 2024**, contrasting the efficiency of the **SyBA web form** against conventional searches in GenBank **(a)** and PubMedCentral **(b)**. The comparison underscores the enhanced efficiency attained through the use of combined gene nomenclature and variation in gene nomenclature for genes **birA**, **folD**, **fruA**, **hsdM**, **hsdR**, **hsdS**, **kdpD**, **mtlA**, **potD**, **pstS**, **putA**, **tnp**, **tnpA**, **wzy** and **wzx**.
***
# SyBA Class Functions
## SyBA init
##### [Go to Contents Overview](#contents-overview)
### `__init__(self, **kwargs)`
The **SyBA** class is initialized with this function. This function serves as the constructor for the class and is invoked when a new **SyBA** class instance is created.
Upon the creation of a **SyBA** class instance, the constructor verifies the existence of the `SyBA_database.tsv` database at the given path. If the database is not found, it will strive to establish the **SyBA directory** and **procure the database from the GitHub repository**.
If the verbose parameter is set to **True**, progress updates will be displayed in the terminal to keep the user informed about the ongoing operations.
#### Parameters:
- `verbose (bool)`: If `True`, messages will be printed during execution. The default is `True`.
#### Returns:
- `None`
#### Notes:
- This function requires the `requests` and `pandas` library to be imported.
- The `SyBA` database is available at github.com/luanrabelo/SyBA.
#### Usage Example:
```python
# Import the SyBA class from the SyBA module.
from SyBA import SyBA
# This function initializes the class and downloads the database from the GitHub repository.
sb = SyBA(verbose=True)
```
#### Output
```
############################## SyBA ##############################
SyBA Class has been initialized!
Version: 0.0.1
Status: Stable
Author: Luan Rabelo
License: MIT
GitHub Page: https://github.com/luanrabelo/SyBA
Consult the documentation in github page for more information.
############################## SyBA ##############################
```
## SyBA update
##### [Go to Contents Overview](#contents-overview)
### `update(self, **kwargs)`
The `update` method updates the **SyBA** database by **fetching it from the GitHub repository's stable branch**. If a database already exists, it's removed before the new one is downloaded.
This method checks for the `SyBA_database.tsv` database file on the user's system. If found, the file is removed. Then, it **downloads the latest database from the GitHub repository URL**.
If verbose is **True**, console messages inform the user about the progress, including the old database's removal and the new one's download.
#### Parameters:
- `verbose (bool)`: If `True`, messages will be printed during execution. The default is `True`.
#### Returns:
- The updated `SyBA` database saved in the `SyBA` folder.
#### Notes:
- This function requires the `requests` library to be imported.
- The `SyBA` database is available at github.com/luanrabelo/SyBA.
#### Usage Example:
```python
# Import the SyBA class from the SyBA module.
from SyBA import SyBA
# This function initializes the class and downloads the database from the GitHub repository.
sb = SyBA(verbose=True)
# This function update SyBA database
sb.update(verbose=True)
```
#### Output
```
2024/03/05 - 16:20:57 - SyBA database found in the current directory!
2024/03/05 - 16:20:57 - SyBA database found in /home/luanrabelo/SyBA/ !
2024/03/05 - 16:20:57 - Removing old SyBA database...
2024/03/05 - 16:20:57 - Old SyBA database removed successfully!
2024/03/05 - 16:20:57 - Downloading SyBA database from https://github.com/luanrabelo/SyBA, please wait...
2024/03/05 - 16:21:00 - Download SyBA database successfully!
```
## SyBA fixName
##### [Go to Contents Overview](#contents-overview)
### `fixName(self, **kwargs)`
Corrects the gene name according to the **SyBA** database, ensuring it adheres to the standardized nomenclature.
The `fixName` function takes a gene name and corrects it based on the entries in the **SyBA** database.
If the provided **gene name is found in the database**, **it is replaced with the standardized short name**.
**If not found**, **the original name is returned, and a log entry is created**.
The function provides verbose output if the verbose parameter is set to **True**.
#### Parameters:
- `dscp (str)`: The gene description, for example, lcl|AASOAZ010000001.1_cds_EFE7820019.1_2 [locus_tag=F6Q14_00010] [protein=pflagellum-specific ATP synthase FliL] [protein_id=EFE7820019.1] [location=complement(1576..1932)] [gbkey=CDS].
- `verbose (bool)`: If set to `True`, messages will be printed during execution. The default is `True`.
#### Returns:
- `ShortName (str)`: The corrected gene name.
#### Notes:
- This function requires the `pandas` and `numpy` library to be imported.
- The `SyBA` database can be found at github.com/luanrabelo/SyBA.
#### Usage Example:
```python
# Import the SyBA class from the SyBA module.
from SyBA import SyBA
# This function initializes the class and downloads the database from the GitHub repository.
sb = SyBA(verbose=True)
# This function fixes the gene name.
geneName = sb.fixName(dscp='[protein=flagellum-specific ATP synthase FliL]', verbose=True)
print(geneName)
```
#### Output
```
fliL
```
## SyBA buildQuery
##### [Go to Contents Overview](#contents-overview)
### `buildQuery(self, **kwargs)`
Constructs a query for **Entrez** search in **GenBank** or **PubMed** using the **SyBA** database.
The `buildQuery` function creates a query string that can be utilized to search for specific gene information in the **GenBank** or **PubMed** databases.
The **search type** is validated against a **list of acceptable formats**.
The **list of acceptable formats** includes **"Title", "Abstract", "All Fields", "MeSH Terms"**.
If the verbose parameter is set to **True**, the function will output informative messages during the process of query construction.
#### Parameters:
- `geneName`: The gene name, for example, `rpoB`.
- `specieName`: The specie name, for example, `Salmonella`.
- `searchType`: The search type, for example, `All Fields`.
- `verbose`: If `True`, the class will print the status of the database and the download process. If `False`, the class will not print anything. Default is `False`.
#### Returns:
- `query (str)`: The query for Entrez search in GenBank or PubMed.
#### Notes:
- This function requires the `pandas` library to be imported.
- The `SyBA` database is available at github.com/luanrabelo/SyBA.
- The `_listTypes` contains the valid formats for the search type.
#### Usage Example:
```python
from SyBA import SyBA
sb = SyBA()
query = sb.buildQuery(specieName='Salmonella', geneName='mntB', searchType='All Fields', verbose=True)
print(query)
```
#### Output
```
2024/03/05 - 18:17:37 - SyBA database found in the current directory!
2024/03/05 - 18:17:37 - Gene: 'mntB' found in SyBA database!
("Salmonella"[Organism] OR "Salmonella"[Title]) AND ("mntB"[All Fields] OR "zinc transport system permease protein"[All Fields] OR "manganese abc transporter (atp-binding protein)"[All Fields] OR "cation abc transporter permease protein"[All Fields] OR "putative manganese transport system membrane protein mntb"[All Fields] OR "manganese transport system membrane protein mntb"[All Fields] OR "manganese transport system membrane protein"[All Fields] OR "cation abc transporter"[All Fields] OR "abc-transporter membrane protein"[All Fields] OR "afed"[All Fields] OR "manganese abc transporter inner membrane permease sitd"[All Fields] OR "chelated iron transport system membrane protein yfed,manganese transport system membrane protein mntb,high-affinity zinc transporter membrane component,anchored repeat-type abc transporter, permease subunit,abc 3 transport family"[All Fields] OR "metal cation abc transporter membrane protein"[All Fields] OR "mn2+/zn2+ abc transporter permease"[All Fields])
```
***
# Example Codes
##### [Go to Contents Overview](#contents-overview)
Navigate to the `Examples` folder to view a **notebook file** that showcases examples of **how to implement** the commands of **SyBA**. This notebook serves as a practical guide, providing step-by-step instructions and examples to help you understand and utilize the functionalities of **SyBA** effectively.
***
# Web Form for SyBA
##### [Go to Contents Overview](#contents-overview)
We’ve created an intuitive web form, accessible at [SyBA web form](https://luanrabelo.github.io/SyBA/), designed for researchers interested in conducting individual searches using different names linked to the same gene. This web form produces a command that includes multiple names, facilitating accurate searches on platforms like the National Center for Biotechnology Information (NCBI) - GenBank and PubMed Central.
![SyBA Web Form](https://raw.githubusercontent.com/luanrabelo/SyBA/stable/assets/img/SyBA.gif "SyBA")
***
# License Information
##### [Go to Contents Overview](#contents-overview)
**SyBA** is **released** under the **MIT License**. This license permits reuse within proprietary software provided that all copies of the licensed software include a copy of the MIT License terms and the copyright notice.
For more details, please see the **MIT License**.
***
# Development Team
##### [Go to Contents Overview](#contents-overview)
- Luan Rabelo
- Marcelo Vallinoto
- Iracilda Sampaio
- Davidson Sodré
- Luiza Helena Meller da Silva
- Grazielle Gomes
***
# Citing SyBA
##### [Go to Contents Overview](#contents-overview)
Soon...
Raw data
{
"_id": null,
"home_page": "https://github.com/luanrabelo/SyBA",
"name": "SyBA",
"maintainer": "Luan Rabelo",
"docs_url": null,
"requires_python": null,
"maintainer_email": "luanrabelo@outlook.com",
"keywords": "SyBA Genes Bioinformatics Synonymous",
"author": "Luan Rabelo",
"author_email": "luanrabelo@outlook.com",
"download_url": "https://files.pythonhosted.org/packages/21/7c/2468805a10418a66c83db35d0469fe4e521c2784b48c9112b53323b4c33e/SyBA-0.0.5.tar.gz",
"platform": null,
"description": "<p align=\"center\">\r\n <img src=\"https://raw.githubusercontent.com/luanrabelo/SyBA/stable/docs/assets/SyBA.png\" alt=\"SyBA Logo\" width=\"25%\">\r\n</p>\r\n\r\n# Contents Overview\r\n- [System Overview](#system-overview)\r\n- [Getting Started with SyBA](#getting-started-with-syba)\r\n - [Prerequisites](#prerequisites)\r\n - [Installation Guide](#installation-guide)\r\n- [Efficiency of SyBA](#efficiency-of-syba)\r\n- [SyBA Class Functions](#syba-class-functions)\r\n - [init](#syba-init)\r\n - [SyBA Update](#syba-update)\r\n - [SyBA fixName](#syba-fixname)\r\n - [SyBA buildQuery](#syba-buildquery)\r\n- [Example Codes](#example-codes)\r\n- [Web Form for SyBA](#web-form-for-syba)\r\n- [License Information](#license-information)\r\n- [Development Team](#development-team)\r\n- [Citing SyBA](#citing-syba)\r\n*** \r\n \r\n# System Overview\r\n##### [Go to Contents Overview](#contents-overview)\r\nSyBA (**Sy**nonymous of **BA**cterial Genes) is a **tool** and **database** for **standardizing gene names in bacterial genomes**. It provides a consistent nomenclature for gene names, allowing researchers to accurately search for genes from bacteria that cause **human diseases**, improving **public health** research on **foodborne illnesses** (Figure 1).\r\n\r\n> ![MarineGEO circle logo](https://raw.githubusercontent.com/luanrabelo/SyBA/stable/assets/img/Figure1.png \"Map\") Figure 1. Global snapshot of the Food Contamination Monitoring and Assessment Programme, highlighting the top 10 countries and various regions. The data is sourced from the Global Environment Monitoring System, avaliable at https://apps.who.int/foscollab/Download/DownloadConta \r\n\r\nThe **SyBA** database is constructed using gene symbols and gene products (proteins) present in **1,215,109 functional bacterial genomes**, based on the genera _Campylobacter_, _Clostridium_, _Escherichia_, _Listeria_, _Salmonella_, _Shigella_, _Staphylococcus_, and _Vibrio_. \r\n\r\n**SyBA** includes a **Python class** for standardizing gene names, which can automatically find and change different name variations into a standard form. The class also generates search commands for specific genes or papers in **GenBank** or **PubMedCentral** with different bacterial gene names. \r\n\r\nAdditionally, **SyBA** provides a **web form** that is **easy-to-use** for **researchers** to **search for specific genes or papers** in **GenBank** or **PubMedCentral**. \r\n\r\nThe **SyBA** repository, hosted on **GitHub** and **licensed under MIT**, is a **freely accessible** resource for the **scientific community**. It offers comprehensive analysis results of bacterial gene names. In addition, it includes thorough **guidelines and sample scripts** to **assist researchers in their work**.\r\n*** \r\n \r\n# Getting Started with **SyBA**\r\n##### [Go to Contents Overview](#contents-overview)\r\n- ## Prerequisites\r\nBefore you run **SyBA**, make sure you have the following prerequisites installed on your system:\r\n- **Python Environment**\r\n - Python **version 3.6 or higher**\r\n - conda (optional)\r\n- Dependencies (these will be automatically installed with pip)\r\n - `requests`\r\n - `pandas`\r\n - `openpyxl` \r\n - `numpy`\r\n- ## Installation Guide\r\nThere are **tree** ways to install **SyBA**:\r\n1. **Through pip**: Install **SyBA** directly using pip: \r\n```bash \r\npip install SyBA\r\n```\r\n- This will install **SyBA** and its **dependencies** in your **Python environment**.\r\n \r\n \r\n2. **By cloning the GitHub repository**: Clone the source code of **SyBA** from GitHub:\r\n```bash\r\ngit clone https://github.com/luanrabelo/SyBA.git\r\ncd SyBA \r\npip install -r requirements.txt\r\n```\r\n- This command will **clone the repository**, and then you should **navigate to the cloned directory** to **install SyBA and its dependencies** using pip.\r\n \r\n \r\n3. Installation via **conda**: You can also install **SyBA** using conda with the following commands: \r\n```bash\r\nconda create -n SyBA -c conda-forge -c bioconda SyBA\r\nconda activate SyBA \r\n```\r\n- This method will set up **SyBA** along with its **dependencies** in a **new conda environment**.\r\n \r\n*** \r\n \r\n# Efficiency of SyBA\r\n##### [Go to Contents Overview](#contents-overview)\r\n> ![SyBA](https://raw.githubusercontent.com/luanrabelo/SyBA/stable/assets/img/Figure2.png \"Comparison\") Figure 2. **(a)** Comparison between the number of gene name variations in the **SyBA database (v1.0.0)** and the number of proteins without a gene name. **(b)** The **15 genes** with the **most name variations** in the **SyBA database (v1.0.0)**. **(c)** By applying the names of proteins that do **not have a gene name**, it is possible to **recover this information** in up to **55.3%** of cases. **(d)** The **time required** for the **SyBA class** to **standardize gene names** in **1000 bacterial genomes**, with the **possibility of executing the function asynchronously** to further **reduce processing time**. **(e)** The time required to **generate 1000 search commands** with gene name variations.\r\n \r\n \r\n> ![SyBA](https://raw.githubusercontent.com/luanrabelo/SyBA/stable/assets/img/Figure3.png \"Comparison\") Figure 3. A comparative analysis of search results in **March 2024**, contrasting the efficiency of the **SyBA web form** against conventional searches in GenBank **(a)** and PubMedCentral **(b)**. The comparison underscores the enhanced efficiency attained through the use of combined gene nomenclature and variation in gene nomenclature for genes **birA**, **folD**, **fruA**, **hsdM**, **hsdR**, **hsdS**, **kdpD**, **mtlA**, **potD**, **pstS**, **putA**, **tnp**, **tnpA**, **wzy** and **wzx**.\r\n \r\n*** \r\n\r\n# SyBA Class Functions\r\n## SyBA init\r\n##### [Go to Contents Overview](#contents-overview)\r\n### `__init__(self, **kwargs)` \r\n\r\nThe **SyBA** class is initialized with this function. This function serves as the constructor for the class and is invoked when a new **SyBA** class instance is created.\r\n\r\nUpon the creation of a **SyBA** class instance, the constructor verifies the existence of the `SyBA_database.tsv` database at the given path. If the database is not found, it will strive to establish the **SyBA directory** and **procure the database from the GitHub repository**.\r\n\r\nIf the verbose parameter is set to **True**, progress updates will be displayed in the terminal to keep the user informed about the ongoing operations.\r\n\r\n#### Parameters:\r\n- `verbose (bool)`: If `True`, messages will be printed during execution. The default is `True`.\r\n#### Returns:\r\n- `None`\r\n#### Notes:\r\n- This function requires the `requests` and `pandas` library to be imported.\r\n- The `SyBA` database is available at github.com/luanrabelo/SyBA.\r\n#### Usage Example:\r\n```python\r\n# Import the SyBA class from the SyBA module.\r\nfrom SyBA import SyBA\r\n# This function initializes the class and downloads the database from the GitHub repository.\r\nsb = SyBA(verbose=True)\r\n```\r\n#### Output\r\n```\r\n############################## SyBA ##############################\r\nSyBA Class has been initialized!\r\nVersion: 0.0.1\r\nStatus: Stable\r\nAuthor: Luan Rabelo\r\nLicense: MIT\r\nGitHub Page: https://github.com/luanrabelo/SyBA\r\nConsult the documentation in github page for more information.\r\n############################## SyBA ##############################\r\n```\r\n \r\n## SyBA update\r\n##### [Go to Contents Overview](#contents-overview)\r\n### `update(self, **kwargs)` \r\nThe `update` method updates the **SyBA** database by **fetching it from the GitHub repository's stable branch**. If a database already exists, it's removed before the new one is downloaded.\r\n\r\nThis method checks for the `SyBA_database.tsv` database file on the user's system. If found, the file is removed. Then, it **downloads the latest database from the GitHub repository URL**.\r\n\r\nIf verbose is **True**, console messages inform the user about the progress, including the old database's removal and the new one's download.\r\n\r\n\r\n#### Parameters:\r\n- `verbose (bool)`: If `True`, messages will be printed during execution. The default is `True`.\r\n\r\n#### Returns:\r\n- The updated `SyBA` database saved in the `SyBA` folder.\r\n\r\n#### Notes:\r\n- This function requires the `requests` library to be imported.\r\n- The `SyBA` database is available at github.com/luanrabelo/SyBA.\r\n\r\n#### Usage Example:\r\n```python\r\n# Import the SyBA class from the SyBA module.\r\nfrom SyBA import SyBA\r\n# This function initializes the class and downloads the database from the GitHub repository.\r\nsb = SyBA(verbose=True)\r\n# This function update SyBA database\r\nsb.update(verbose=True)\r\n```\r\n#### Output\r\n```\r\n2024/03/05 - 16:20:57 - SyBA database found in the current directory!\r\n2024/03/05 - 16:20:57 - SyBA database found in /home/luanrabelo/SyBA/ !\r\n2024/03/05 - 16:20:57 - Removing old SyBA database...\r\n2024/03/05 - 16:20:57 - Old SyBA database removed successfully!\r\n2024/03/05 - 16:20:57 - Downloading SyBA database from https://github.com/luanrabelo/SyBA, please wait...\r\n2024/03/05 - 16:21:00 - Download SyBA database successfully!\r\n```\r\n \r\n\r\n## SyBA fixName\r\n##### [Go to Contents Overview](#contents-overview)\r\n### `fixName(self, **kwargs)`\r\nCorrects the gene name according to the **SyBA** database, ensuring it adheres to the standardized nomenclature. \r\n\r\nThe `fixName` function takes a gene name and corrects it based on the entries in the **SyBA** database.\r\nIf the provided **gene name is found in the database**, **it is replaced with the standardized short name**.\r\n**If not found**, **the original name is returned, and a log entry is created**.\r\nThe function provides verbose output if the verbose parameter is set to **True**.\r\n\r\n#### Parameters:\r\n- `dscp (str)`: The gene description, for example, lcl|AASOAZ010000001.1_cds_EFE7820019.1_2 [locus_tag=F6Q14_00010] [protein=pflagellum-specific ATP synthase FliL] [protein_id=EFE7820019.1] [location=complement(1576..1932)] [gbkey=CDS].\r\n- `verbose (bool)`: If set to `True`, messages will be printed during execution. The default is `True`.\r\n\r\n#### Returns:\r\n- `ShortName (str)`: The corrected gene name.\r\n\r\n#### Notes:\r\n- This function requires the `pandas` and `numpy` library to be imported.\r\n- The `SyBA` database can be found at github.com/luanrabelo/SyBA.\r\n\r\n#### Usage Example:\r\n ```python\r\n# Import the SyBA class from the SyBA module.\r\nfrom SyBA import SyBA\r\n# This function initializes the class and downloads the database from the GitHub repository.\r\nsb = SyBA(verbose=True)\r\n# This function fixes the gene name.\r\ngeneName = sb.fixName(dscp='[protein=flagellum-specific ATP synthase FliL]', verbose=True)\r\nprint(geneName)\r\n```\r\n#### Output\r\n```\r\nfliL\r\n```\r\n \r\n\r\n## SyBA buildQuery\r\n##### [Go to Contents Overview](#contents-overview)\r\n### `buildQuery(self, **kwargs)`\r\nConstructs a query for **Entrez** search in **GenBank** or **PubMed** using the **SyBA** database.\r\n\r\nThe `buildQuery` function creates a query string that can be utilized to search for specific gene information in the **GenBank** or **PubMed** databases.\r\n\r\nThe **search type** is validated against a **list of acceptable formats**.\r\n\r\nThe **list of acceptable formats** includes **\"Title\", \"Abstract\", \"All Fields\", \"MeSH Terms\"**.\r\n\r\nIf the verbose parameter is set to **True**, the function will output informative messages during the process of query construction.\r\n\r\n#### Parameters:\r\n- `geneName`: The gene name, for example, `rpoB`.\r\n- `specieName`: The specie name, for example, `Salmonella`.\r\n- `searchType`: The search type, for example, `All Fields`.\r\n- `verbose`: If `True`, the class will print the status of the database and the download process. If `False`, the class will not print anything. Default is `False`.\r\n\r\n#### Returns:\r\n- `query (str)`: The query for Entrez search in GenBank or PubMed.\r\n\r\n#### Notes:\r\n- This function requires the `pandas` library to be imported.\r\n- The `SyBA` database is available at github.com/luanrabelo/SyBA.\r\n- The `_listTypes` contains the valid formats for the search type.\r\n\r\n#### Usage Example:\r\n```python\r\nfrom SyBA import SyBA\r\nsb = SyBA()\r\nquery = sb.buildQuery(specieName='Salmonella', geneName='mntB', searchType='All Fields', verbose=True)\r\nprint(query)\r\n```\r\n#### Output\r\n```\r\n2024/03/05 - 18:17:37 - SyBA database found in the current directory!\r\n2024/03/05 - 18:17:37 - Gene: 'mntB' found in SyBA database!\r\n(\"Salmonella\"[Organism] OR \"Salmonella\"[Title]) AND (\"mntB\"[All Fields] OR \"zinc transport system permease protein\"[All Fields] OR \"manganese abc transporter (atp-binding protein)\"[All Fields] OR \"cation abc transporter permease protein\"[All Fields] OR \"putative manganese transport system membrane protein mntb\"[All Fields] OR \"manganese transport system membrane protein mntb\"[All Fields] OR \"manganese transport system membrane protein\"[All Fields] OR \"cation abc transporter\"[All Fields] OR \"abc-transporter membrane protein\"[All Fields] OR \"afed\"[All Fields] OR \"manganese abc transporter inner membrane permease sitd\"[All Fields] OR \"chelated iron transport system membrane protein yfed,manganese transport system membrane protein mntb,high-affinity zinc transporter membrane component,anchored repeat-type abc transporter, permease subunit,abc 3 transport family\"[All Fields] OR \"metal cation abc transporter membrane protein\"[All Fields] OR \"mn2+/zn2+ abc transporter permease\"[All Fields])\r\n```\r\n*** \r\n \r\n\r\n# Example Codes\r\n##### [Go to Contents Overview](#contents-overview)\r\nNavigate to the `Examples` folder to view a **notebook file** that showcases examples of **how to implement** the commands of **SyBA**. This notebook serves as a practical guide, providing step-by-step instructions and examples to help you understand and utilize the functionalities of **SyBA** effectively.\r\n*** \r\n \r\n\r\n# Web Form for SyBA\r\n##### [Go to Contents Overview](#contents-overview)\r\n\r\nWe\u00e2\u20ac\u2122ve created an intuitive web form, accessible at [SyBA web form](https://luanrabelo.github.io/SyBA/), designed for researchers interested in conducting individual searches using different names linked to the same gene. This web form produces a command that includes multiple names, facilitating accurate searches on platforms like the National Center for Biotechnology Information (NCBI) - GenBank and PubMed Central. \r\n \r\n\r\n![SyBA Web Form](https://raw.githubusercontent.com/luanrabelo/SyBA/stable/assets/img/SyBA.gif \"SyBA\")\r\n \r\n\r\n*** \r\n \r\n\r\n# License Information\r\n##### [Go to Contents Overview](#contents-overview)\r\n**SyBA** is **released** under the **MIT License**. This license permits reuse within proprietary software provided that all copies of the licensed software include a copy of the MIT License terms and the copyright notice.\r\n\r\nFor more details, please see the **MIT License**.\r\n \r\n*** \r\n \r\n# Development Team\r\n##### [Go to Contents Overview](#contents-overview)\r\n- Luan Rabelo\r\n- Marcelo Vallinoto\r\n- Iracilda Sampaio\r\n- Davidson Sodr\u00c3\u00a9\r\n- Luiza Helena Meller da Silva\r\n- Grazielle Gomes\r\n \r\n*** \r\n \r\n# Citing SyBA\r\n##### [Go to Contents Overview](#contents-overview)\r\nSoon...\r\n",
"bugtrack_url": null,
"license": "MIT License",
"summary": "SyBA: a tool and database for standardizing gene names from the main bacterial pathogens causing food contamination",
"version": "0.0.5",
"project_urls": {
"Download": "https://github.com/luanrabelo/SyBA",
"Homepage": "https://github.com/luanrabelo/SyBA"
},
"split_keywords": [
"syba",
"genes",
"bioinformatics",
"synonymous"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "2297893e8f1a357985f4a66a7db73bcf99238fbbbb34c13a9ef88115903c590c",
"md5": "5bb76167f046603de2c15ee48bdefebf",
"sha256": "b72c7d0abe94f5a079c458480d26509a83da8764b1f511f4dae047469ddfddcf"
},
"downloads": -1,
"filename": "SyBA-0.0.5-py3-none-any.whl",
"has_sig": false,
"md5_digest": "5bb76167f046603de2c15ee48bdefebf",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 10973,
"upload_time": "2024-03-22T16:16:35",
"upload_time_iso_8601": "2024-03-22T16:16:35.834036Z",
"url": "https://files.pythonhosted.org/packages/22/97/893e8f1a357985f4a66a7db73bcf99238fbbbb34c13a9ef88115903c590c/SyBA-0.0.5-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "217c2468805a10418a66c83db35d0469fe4e521c2784b48c9112b53323b4c33e",
"md5": "55998e94f8512a1053b04343a17e6af0",
"sha256": "daad5c76745deb87d91b072350c981b14fbb3aefdd3a29afcbbc8b01c89c8a86"
},
"downloads": -1,
"filename": "SyBA-0.0.5.tar.gz",
"has_sig": false,
"md5_digest": "55998e94f8512a1053b04343a17e6af0",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 14813,
"upload_time": "2024-03-22T16:16:37",
"upload_time_iso_8601": "2024-03-22T16:16:37.562897Z",
"url": "https://files.pythonhosted.org/packages/21/7c/2468805a10418a66c83db35d0469fe4e521c2784b48c9112b53323b4c33e/SyBA-0.0.5.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-03-22 16:16:37",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "luanrabelo",
"github_project": "SyBA",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "syba"
}