-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathget_id_phasmida.m
57 lines (47 loc) · 1.24 KB
/
get_id_phasmida.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
%% get_id_phasmida
% gets id of species name in Phasmida Species File Online
%%
function id = get_id_phasmida(my_pet, open)
% created 2021/08/13 by Bas Kooijman
%% Syntax
% id = <../get_id_phasmida.m *get_id_phasmida*>(my_pet, open)
%% Description
% Gets identifier for Phasmida Species File Online
%
% Input:
%
% * my_pet: character string with name of a taxon
% * open: optional boolean for opening in browser (default: 0)
%
% Output:
%
% * id: character string with id in Phasmida Species File Online
%% Remarks
% Outputs empty strings if identification was not successful.
%% Example of use
% id = get_id_phasmida('Extatosoma_tiaratum',1)
address = 'http://lsid.speciesfile.org/urn:lsid:Phasmida.speciesfile.org:TaxonName:';
if ~exist('open','var')
open = 0;
end
my_pet = strrep(my_pet,' ','+');
my_pet = strrep(my_pet,'_','+');
try
url = urlread(['http://webservice.catalogueoflife.org/col/webservice?name=', my_pet]);
catch
id = ''; return
end
i_0 = strfind(url, 'Phasmida.speciesfile.org:TaxonName:');
if isempty(i_0)
id = ''; return
end
i_0 = i_0(1) + 35; i_1 = strfind(url(i_0:end),'</online_resource>') - 2 + i_0(1);
id = url(i_0:i_1(1));
try
urlread([address, id]);
catch
id = ''; return
end
if open
web([address, id],'-browser');
end