Changelog
0.2.0
-
cpauth module
- Remove legacy authentication.
- Authenticate via icoscp_core.
-
stilt module
- The module is moved out to a new library
icoscp_stilt
.
- The module is moved out to a new library
-
countries module
- The module has been removed, as its only usage was from the
stilt
module. - Within the new
icoscp_stilt
library, the geo information handling has been radically simplified, making thecountries
module redundant.
- The module has been removed, as its only usage was from the
-
dependencies
- Dependencies
fiona
andgeopandas
are gone due tostilt
module removal.
- Dependencies
-
documentation
- Move the
cpauth
module to the Getting started section. - Add Upgrade guide to the installation section.
- Add substantial amount of content to the About page.
- Add Getting started examples and move the old examples to a separate section as legacy.
- Remove most of the old FAQ, add a few new ones.
- Move the
0.1.20
-
country module
- Make the reverse geocoding functionality available only to users with access to the ICOS Jupyter Hub.
- Replace the nominatim reverse geocoder with on-server access to shapefiles.
-
cpauth module
- Enforce secure data access via mandatory authentication.
-
sparql module
- Accept cached SPARQL responses by default.
-
stilt module
- Obtain country information more accurately.
0.1.19
-
stilt module
- Filter out
.zip
data files fromstiltweb
data structure.
- Filter out
-
documentation
- Apply Tyler's changes in the file
README.md
.
- Apply Tyler's changes in the file
-
project-structure
0.1.18
-
cpauth module
Implement authentication for secure data access. The full documentation of the authentication module can be found here. -
cpb module
- Rework code in
Dobj()
class to correctly addseries
to pandasDataFrame
and avoid pandas performance warning. - Verify timestamp format of binary files and convert accordingly to avoid error in data accessing.
- Rework code in
-
stilt module
- Remove mutable default arguments from functions in the
stilt
module. - Update availability table, such that only 'real' ICOS stations get an ICOS id.
- Add ICOS sampling height to the ICOS dictionary.
- Add corresponding data files to the ICOS dictionary.
- Increase performance when reading
STILT
footprints. - Replace
eval()
statement to prevent security risks. - Make function
station.get()
case-insensitive.
- Remove mutable default arguments from functions in the
-
station module
- Remove elevation above ground attribute from
Station()
class. - Update documentation on how to correctly retrieve station names when
iterating over pandas
DataFrames'
rows.
- Remove elevation above ground attribute from
0.1.17
-
station module
The station class has been somewhat optimized:station.getList()
is fasterstation.getIdList()
has a new parametertheme
(as ingetList
)
-
sparql module
In the background the station class use sparql queries, andsparqls.py
has been endowed with station query function:sparqls.station_query()
, the function has a filter parameter with which the experienced user for example can use to fetch stations in a list of countries.
-
stilt module
- Update
xarray
call instiltobj.py
.
- Update
-
other changes
- Fix library's building problems which resulted in an empty project description here: https://pypi.org/project/icoscp/
0.1.16
-
sparql
- Remove methods with unused queries
cpbGetInfo(dobj)
andcpbGetSchemaDetail(formatSpec)
. - Speed up queries in functions
objectSpec(spec='atcCo2L2DataObject', station='', limit=0)
,getStations(station = '')
,get_coords_icos_stations_atc()
, andget_icos_stations_atc_L1()
. - Update query in
getStations(station = '')
to correctly retrieve stations. - Add deprecation warning for
stations_with_pi()
query.
- Remove methods with unused queries
-
station module
- Filter out non icos stations when querying themed stations in
getList()
.
- Filter out non icos stations when querying themed stations in
-
stilt module
- Regenerate STILT module's static file
stations.json
.
- Regenerate STILT module's static file
0.1.15
-
cpb module
- Dobj change to read metadata from http request. Instead of using sparql queries, a http request is used to load the same meta data as available from the website.
- Add new script to extract metadata from server
metadata.py
. - Add new property
.meta
returns a dictionary based on the meta data available from the landing page of a data object containing a very rich set of information. An example: https://meta.icos-cp.eu/objects/M8STRfcQfU4Yj7Uy0snHvlve/meta.json - Add new property:
.previous
Return the pid/url of the previous version of this file if available. - Add new property:
.next
-> Return the pid/url of the next version of this file if available. - Add new property:
.variables
Return a PandasDataFrame with metadata for all variables ['name', 'unit', 'type', 'format']. - Add new property:
.alt
Returns altitude of station, the same as.elevation
. - Remove properties:
._info1
,._info2
,._info3
from Dobj. - Change
.info
(consisted of info 1,2,3,) and return.meta
instead. - Change
.station
: Returns a dictionary with a subset of .meta describing the station. - Change of
.colNames
: returns now a list of strings with all variable names instead of a pandas core series. - License is extracted dynamically from the metadata per object.
- Add new method
get_citation(format='plain')
. Returns the citation by default as plain string, the same as .citation (property) which internally calls this method. Argument options are ('bibtex', 'ris', 'plain') ->.citation('bibtex'|'ris'|'plain')
. print(Dobj)
output of __str__ changed to plain citation string, instead of pid.- References to server calls moved to
const.py
. - Rename file dtype_dict.py to dtype.py for better readability.
- add simple unit test and implement initial assertions for the cpb module.
-
access to data
.data
[property] will always return all columns..get(columns=None)
[method] returns all data by default. Provides the possibility to extract specific columns from the data set. Expected is a list of column names, which then returns only the selected columns. Non valid entries are removed from the list (if only non valid entries are provided, an empty list by default returns all columns). Please be aware, that.get()
will ALWAYS return ALL columns if executed on the Carbon Portal server. Valid entries can be obtained with.colNames
or `.variables['name']..getColumns(columns=None)
, this is exactly the same as .get(columns='None'). We keep this function for compatibility to previous versions.
-
other changes
- add
icon
argument tostation.getIdList()
function. - regenerate STILT module's static
stations.json
. - resolve deprecation warnings from
numpy
calls. - implement
stiltstation.find()
byproject
. - add
outfmt='avail'
argument tostiltstation.find()
function to generate an availability table forSTILT stations
. - fix
stiltstation.find(outfmt='list')
. - fix
print(stiltobj)
by removing country information. Country information can still be retrieved using the.info
attribute of theStilStation
object.
- add
0.1.14
- update
get_ts()
to case-insensitive and includeco2.bio.gee
andco2.bio.resp
in theco2
results - correctly redirect nominatim requests when icos nominatim is unable to reverse geocode.
0.1.13
- rework directory listing of STILT stations and ignore queued but empty stations
0.1.12
- fix
stiltstation.find()
to return all STILT stations - switch to ICOS reverse geocoder as default
- precompute all known stations to speed up search functions
- if possible, use ICOS station's latitude/longitude when reverse geocoding a STILT station for precision
0.1.11
- rework process of requesting stilt stations
- add a progress bar when requesting stilt stations
- update user information when using the stilt module
- add stilt data reporting to the back-end
0.1.10
- adjust pylib version reported to the back-end
- include non-code files to distribution
- inform users when wrongly accessing the Stilt module locally
0.1.9
- add Stilt module and documentation
- add local country information
- add folium map extension to
getIdList()
function
0.1.8
- change licence on https://pypi.org/project/icoscp/ to https://www.icos-cp.eu/data-services/about-data-portal/data-license
- adjust portal use internal flag
0.1.7
- add licence attribute to Dobj()
- handle single str input to station.getList()
- stats report distinguish between intern/external usage
- remove _checkdata flag from station.info()
- update documentation
0.1.6
- 2021/03/29
- add sparql queries for availability table
- typos and additions to documentation
- move changelog to separate file
0.1.5
- 2020/10/20
- fix bug introduced with v 0.1.4
- datasets with optional columns where not loaded if data object specifications mismatched the list of columns
0.1.4
-2020/10/16 - add support for regex columns
0.1.3
- 2020/10/01
- Add module 'collection' to support loading data products. See Modules / collection
- Change behaviour of Dobj to keep data persistent. The pandas data frame is now persistent stored as pandas dataframe in the object. Older versions did query the server every time for the data. A new attribute is available:
Dobj.data
which returns the pandas dataframe. This change in behaviour is controlled withDobj._datapersistent = True
(default), and can be reverted by setting it to False. - A new attribute
Dobj.id
is available (which is equivalent to Dobj.dobj) but is more human understandable. Dobj.id retrieves or sets the PID/URI.
0.1.2
- 2020/07/15
- first public version to pypi.org