Retrieves features (e.g. genes, transcripts, variants and more) that overlap a region defined by the given identifier.
Name | Type | Description | Default | Example Values |
---|---|---|---|---|
feature | Enum(band, gene, transcript, cds, exon, repeat, simple, misc, variation, somatic_variation, structural_variation, somatic_structural_variation, constrained, regulatory, motif, mane) | The type of feature to retrieve. Multiple values are accepted. | none | - |
id | String | An Ensembl stable ID | - |
ENSG00000157764 |
Name | Type | Description | Default | Example Values |
---|---|---|---|---|
biotype | String | The functional classification of the gene or transcript to fetch. Cannot be used in conjunction with logic_name when querying transcripts. | - |
protein_coding |
callback | String | Name of the callback subroutine to be returned by the requested JSONP response. Required ONLY when using JSONP as the serialisation method. Please see the user guide. | - |
randomlygeneratedname |
db_type | String | Restrict the search to a database other than the default. Useful if you need to use a DB other than core | - |
core |
logic_name | String | Limit retrieval of genes, transcripts and exons by a given name of an analysis. | - | - |
misc_set | String | Miscellaneous set which groups together feature entries. Consult the DB or returned data sets to discover what is available. | - |
cloneset_30k |
object_type | String | Filter by feature type | - |
gene |
so_term | String | Sequence Ontology term to narrow down the possible variants returned. | - |
SO:0001650 |
species | String | Species name/alias. | - |
homo_sapiens |
species_set | String | Filter by species set for retrieving constrained elements. | mammals | - |
variant_set | String | Short name of a set to restrict the variants found. (See list of short set names) | - |
ClinVar |
use strict; use warnings; use HTTP::Tiny; my $http = HTTP::Tiny->new(); my $server = 'http://grch37.rest.ensembl.org'; my $ext = '/overlap/id/ENSG00000157764?feature=gene'; my $response = $http->get($server.$ext, { headers => { 'Content-type' => 'application/json' } }); die "Failed!\n" unless $response->{success}; use JSON; use Data::Dumper; if(length $response->{content}) { my $hash = decode_json($response->{content}); local $Data::Dumper::Terse = 1; local $Data::Dumper::Indent = 1; print Dumper $hash; print "\n"; }
import requests, sys server = "http://grch37.rest.ensembl.org" ext = "/overlap/id/ENSG00000157764?feature=gene" r = requests.get(server+ext, headers={ "Content-Type" : "application/json"}) if not r.ok: r.raise_for_status() sys.exit() decoded = r.json() print repr(decoded)
import requests, sys server = "http://grch37.rest.ensembl.org" ext = "/overlap/id/ENSG00000157764?feature=gene" r = requests.get(server+ext, headers={ "Content-Type" : "application/json"}) if not r.ok: r.raise_for_status() sys.exit() decoded = r.json() print(repr(decoded))
require 'net/http' require 'uri' server='http://grch37.rest.ensembl.org' path = '/overlap/id/ENSG00000157764?feature=gene' url = URI.parse(server) http = Net::HTTP.new(url.host, url.port) request = Net::HTTP::Get.new(path, {'Content-Type' => 'application/json'}) response = http.request(request) if response.code != "200" puts "Invalid response: #{response.code}" puts response.body exit end require 'rubygems' require 'json' require 'yaml' result = JSON.parse(response.body) puts YAML::dump(result)
import java.net.URL; import java.net.URLConnection; import java.net.HttpURLConnection; import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.io.IOException; import java.io.Reader; public class EnsemblRest { public static void main(String[] args) throws Exception { String server = "http://grch37.rest.ensembl.org"; String ext = "/overlap/id/ENSG00000157764?feature=gene"; URL url = new URL(server + ext); URLConnection connection = url.openConnection(); HttpURLConnection httpConnection = (HttpURLConnection)connection; httpConnection.setRequestProperty("Content-Type", "application/json"); InputStream response = connection.getInputStream(); int responseCode = httpConnection.getResponseCode(); if(responseCode != 200) { throw new RuntimeException("Response code was not 200. Detected response was "+responseCode); } String output; Reader reader = null; try { reader = new BufferedReader(new InputStreamReader(response, "UTF-8")); StringBuilder builder = new StringBuilder(); char[] buffer = new char[8192]; int read; while ((read = reader.read(buffer, 0, buffer.length)) > 0) { builder.append(buffer, 0, read); } output = builder.toString(); } finally { if (reader != null) try { reader.close(); } catch (IOException logOrIgnore) { logOrIgnore.printStackTrace(); } } System.out.println(output); } }
library(httr) library(jsonlite) library(xml2) server <- "http://grch37.rest.ensembl.org" ext <- "/overlap/id/ENSG00000157764?feature=gene" r <- GET(paste(server, ext, sep = ""), content_type("application/json")) stop_for_status(r) # use this if you get a simple nested list back, otherwise inspect its structure # head(data.frame(t(sapply(content(r),c)))) head(fromJSON(toJSON(content(r))))
curl 'http://grch37.rest.ensembl.org/overlap/id/ENSG00000157764?feature=gene' -H 'Content-type:application/json'
wget -q --header='Content-type:application/json' 'http://grch37.rest.ensembl.org/overlap/id/ENSG00000157764?feature=gene' -O -
Methods | GET |
Response formats | json xml gff3 bed jsonp |
Slice length | 5e6 |