|  | ERDDAP Easier access to scientific data | |   Brought to you by NOAA NMFS SWFSC ERD | 
 Data Access Protocol (DAP)
  Data Access Protocol (DAP) and its
  selection constraints
 and its
  selection constraints .
.
The URL specifies what you want: the dataset, a description of the graph or the subset of the data, and the file type for the response.
Tabledap request URLs must be in the form
https://coastwatch.pfeg.noaa.gov/erddap/tabledap/datasetID.fileType{?query}
For example,
https://coastwatch.pfeg.noaa.gov/erddap/tabledap/pmelTaoDySst.htmlTable?longitude,latitude,time,station,wmo_platform_code,T_25&time>=2015-05-23T12:00:00Z&time<=2015-05-31T12:00:00Z
Thus, the query is often a comma-separated list of desired variable names,
   followed by a collection of
  constraints (e.g., variable<value),
  each preceded by '&' (which is interpreted as "AND").
Details:
Which fileType should I use?
  
It's entirely up to you. In general, pick the fileType which meets your needs and is easiest to use. You will
  use different fileTypes in different situations, e.g., viewing a graph in a browser (.png) vs. viewing the data
  in a browser (.htmlTable) vs. downloading a data file (e.g., .nc or .csv) vs. working with some software tool
  (e.g., .nc or .odv). If you are going to download lots of large files, you might also want to give some weight
  to fileTypes that are more compact and so can be downloaded faster.
  
The fileType options for downloading tabular data are:
  
 
  
| Data fileTypes | Description | Info | Example | 
|---|---|---|---|
| .asc | View OPeNDAP-style ISO-8859-1 comma-separated text. | info  | example | 
| .csv | Download a ISO-8859-1 comma-separated text table (line 1: names; line 2: units; ISO 8601 times). | info  | example | 
| .csvp | Download a ISO-8859-1 .csv file with line 1: name (units). Times are ISO 8601 strings. | info  | example | 
| .csv0 | Download a ISO-8859-1 .csv file without column names or units. Times are ISO 8601 strings. | info  | example | 
| .dataTable | A JSON file formatted for use with the Google Visualization client library (Google Charts). | info  | example | 
| .das | View the dataset's metadata via an ISO-8859-1 OPeNDAP Dataset Attribute Structure (DAS). | info  | example | 
| .dds | View the dataset's structure via an ISO-8859-1 OPeNDAP Dataset Descriptor Structure (DDS). | info  | example | 
| .dods | OPeNDAP clients use this to download the data in the DODS binary format. | info  | example | 
| .esriCsv | Download a ISO_8859_1 .csv file for ESRI's ArcGIS 9.x and below (separate date and time columns). | info  | example | 
| .fgdc | View the dataset's UTF-8 FGDC .xml metadata. | info  | example | 
| .geoJson | Download longitude,latitude,otherColumns data as a UTF-8 GeoJSON .json file. | info  | example | 
| .graph | View a Make A Graph web page. | info  | example | 
| .help | View a web page with a description of tabledap. | info  | example | 
| .html | View an OPeNDAP-style HTML Data Access Form. | info  | example | 
| .htmlTable | View a UTF-8 .html web page with the data in a table. Times are ISO 8601 strings. | info  | example | 
| .iso19115 | View the dataset's ISO 19115-2/19139 UTF-8 .xml metadata. | info  | example | 
| .itx | Download an ISO-8859-1 Igor Text File. Each response column becomes a wave. | info  | example | 
| .json | View a table-like UTF-8 JSON file (missing value = 'null'; times are ISO 8601 strings). | info  | example | 
| .jsonlCSV1 | View a UTF-8 JSON Lines CSV file with column names on line 1 (mv = 'null'; times are ISO 8601 strings). | info  | example | 
| .jsonlCSV | View a UTF-8 JSON Lines CSV file without column names (mv = 'null'; times are ISO 8601 strings). | info  | example | 
| .jsonlKVP | View a UTF-8 JSON Lines file with Key:Value pairs (missing value = 'null'; times are ISO 8601 strings). | info  | example | 
| .mat | Download a MATLAB binary file. | info  | example | 
| .nc | Download a flat, table-like, NetCDF-3 binary file with COARDS/CF/ACDD metadata. | info  | example | 
| .ncHeader | View the UTF-8 header (the metadata) for the NetCDF-3 .nc file. | info  | example | 
| .ncCF | Download a NetCDF-3 CF Discrete Sampling Geometries file (Contiguous Ragged Array). | info  | example | 
| .ncCFHeader | View the UTF-8 header (the metadata) for the .ncCF file. | info  | example | 
| .ncCFMA | Download a NetCDF-3 CF Discrete Sampling Geometries file (Multidimensional Array). | info  | example | 
| .ncCFMAHeader | View the UTF-8 header (the metadata) for the .ncCFMA file. | info  | example | 
| .nccsv | Download a NetCDF-3-like 7-bit ASCII NCCSV .csv file with COARDS/CF/ACDD metadata. | info  | example | 
| .nccsvMetadata | View the dataset's metadata as the top half of a 7-bit ASCII NCCSV .csv file. | info  | example | 
| .ncoJson | Download a UTF-8 NCO lvl=2 JSON file with COARDS/CF/ACDD metadata. | info  | example | 
| .odvTxt | Download longitude,latitude,time,otherColumns as an ISO-8859-1 ODV Generic Spreadsheet File (.txt). | info  | example | 
| .parquet | Download as a parquet file. Metadata contains column names ("column_names") and units ("column_units"). | info  | example | 
| .parquetWMeta | Download as a parquet file with detailed metadata. | info  | example | 
| .subset | View an HTML form which uses faceted search to simplify picking subsets of the data. | info  | example | 
| .tsv | Download a ISO-8859-1 tab-separated text table (line 1: names; line 2: units; ISO 8601 times). | info  | example | 
| .tsvp | Download a ISO-8859-1 .tsv file with line 1: name (units). Times are ISO 8601 strings. | info  | example | 
| .tsv0 | Download a ISO-8859-1 .tsv file without column names or units. Times are ISO 8601 strings. | info  | example | 
| .wav | Download a .wav audio file. All columns must be numeric and of the same type. | info  | example | 
| .xhtml | View a UTF-8 XHTML (XML) file with the data in a table. Times are ISO 8601 strings. | info  | example | 
ArcGIS .esriCsv
  .esriCsv - ArcGIS
      is a family of Geographical Information Systems (GIS) products from ESRI:
  ArcView, ArcEditor, and ArcInfo.  To get data from ERDDAP into your ArcGIS program (version 9.x and below):
  - ArcGIS
      is a family of Geographical Information Systems (GIS) products from ESRI:
  ArcView, ArcEditor, and ArcInfo.  To get data from ERDDAP into your ArcGIS program (version 9.x and below):
  
 .)
.)
  Ferret is
    a free program for visualizing and analyzing large and complex
  gridded datasets.  Because tabledap's tabular datasets are very different
  from gridded datasets, it is necessary to use Ferret in a very specific way to
  avoid serious problems and misunderstandings:
 
    is
    a free program for visualizing and analyzing large and complex
  gridded datasets.  Because tabledap's tabular datasets are very different
  from gridded datasets, it is necessary to use Ferret in a very specific way to
  avoid serious problems and misunderstandings:
IDL - 
    IDL
    is a commercial scientific data visualization program. To get data from
  ERDDAP into IDL, first use ERDDAP to select a subset of data and download a .nc file.
  Then, use these
    instructions
 - 
    IDL
    is a commercial scientific data visualization program. To get data from
  ERDDAP into IDL, first use ERDDAP to select a subset of data and download a .nc file.
  Then, use these
    instructions to import the data from the .nc file into IDL.
    to import the data from the .nc file into IDL.
  
JSON .json files
    are widely used to transfer data to JavaScript scripts running on web pages.
  All .json responses from ERDDAP (metadata, gridded data, and tabular/in-situ data) use the
  same basic format: a database-like table.  Since data from EDDTable datasets is already a table
  (with a column for each requested variable), ERDDAP can easily store the data in a .json file.
  For example,
    files
    are widely used to transfer data to JavaScript scripts running on web pages.
  All .json responses from ERDDAP (metadata, gridded data, and tabular/in-situ data) use the
  same basic format: a database-like table.  Since data from EDDTable datasets is already a table
  (with a column for each requested variable), ERDDAP can easily store the data in a .json file.
  For example,
    
{
  "table": {
    "columnNames": ["longitude", "latitude", "time", "bottle_posn", "temperature1"],
    "columnTypes": ["float", "float", "String", "byte", "float"],
    "columnUnits": ["degrees_east", "degrees_north", "UTC", null, "degree_C"],
    "rows": [
      [-124.82, 42.95, "2002-08-17T00:49:00Z", 1, 8.086],
      [-124.82, 42.95, "2002-08-17T00:49:00Z", 2, 8.585],
      [-124.82, 42.95, "2002-08-17T00:49:00Z", 3, 8.776],
      ...
      [-124.1, 44.65, "2002-08-19T20:18:00Z", 3, null]
    ]
  }
}
      All .json responses from ERDDAP have
      JSONP (from .json
    (from .json and
    .geoJson
 and
    .geoJson ) -
  Jsonp
       is an easy way for a JavaScript script on a web
  page to import and access data from ERDDAP.  Requests for .geoJson, .json, and .ncoJson files may
  include an optional jsonp request by adding &.jsonp=functionName
  to the end of the query.
  Basically, this just tells ERDDAP to add functionName(
  to the beginning of the response
  and ")" to the end of the response.
  The functionName must be a series of 1 or more (period-separated) words.
  For each word, the first character of functionName must be an ISO 8859 letter or "_".
  Each optional subsequent character must be an ISO 8859 letter, "_", or a digit.
  If originally there was no query, leave off the "&" in your query.
  After the data download to the web page has finished, the data is accessible to the JavaScript
  script via that JavaScript function.
  Here is an example using 
  jsonp and Javascript with ERDDAP
) -
  Jsonp
       is an easy way for a JavaScript script on a web
  page to import and access data from ERDDAP.  Requests for .geoJson, .json, and .ncoJson files may
  include an optional jsonp request by adding &.jsonp=functionName
  to the end of the query.
  Basically, this just tells ERDDAP to add functionName(
  to the beginning of the response
  and ")" to the end of the response.
  The functionName must be a series of 1 or more (period-separated) words.
  For each word, the first character of functionName must be an ISO 8859 letter or "_".
  Each optional subsequent character must be an ISO 8859 letter, "_", or a digit.
  If originally there was no query, leave off the "&" in your query.
  After the data download to the web page has finished, the data is accessible to the JavaScript
  script via that JavaScript function.
  Here is an example using 
  jsonp and Javascript with ERDDAP (thanks to Jenn Patterson Sevadjian of PolarWatch).
 (thanks to Jenn Patterson Sevadjian of PolarWatch).
  
MATLAB .mat
     .mat - Matlab
      users can use tabledap's .mat file type to download data from within
  MATLAB.  Here is a one line example:
   - Matlab
      users can use tabledap's .mat file type to download data from within
  MATLAB.  Here is a one line example:
load(urlwrite('https://coastwatch.pfeg.noaa.gov/erddap/tabledap/pmelTaoDySst.mat?time,T_25&station="0n0e"&time>=2015-05-23T12:00:00Z&time<=2015-05-31T12:00:00Z&.draw=lines', 'test.mat'));
  (You may need to percent encode the query part of the URL.)
  The data will be in a MATLAB structure. The structure's name will be the datasetID
  (for example, pmelTaoDySst). 
  The structure's internal variables will be column vectors with the same names
  as in ERDDAP 
    (for example, use fieldnames(pmelTaoDySst)). 
  You can then make a scatterplot of any two columns. For example:plot(pmelTaoDySst.time, pmelTaoDySst.T_25)
ERDDAP stores datetime values in .mat files as "seconds since 1970-01-01T00:00:00Z". To display one of these values as a String in Matlab, you can use, e.g., datastr(cwwcNDBCMet.time(1)/86400 + 719529) 86400 converts ERDDAP's "seconds since" to Matlab's "days since". 719529 converts ERDDAP's base time of "1970-01-01T00:00:00Z" to Matlab's "0000-01-00T00:00:00Z".
.mat files have a maximum length for identifier names of 32 characters. If a variable name is longer than that, ERDDAP changes the name of the variable when writing the .mat file: it generates a hash digest of the variable name and appends that after the first 25 characters. Thus, long variable names that only differ at the end will still have unique names in the .mat file. ERDDAP administrators: you can avoid this problem by specifying shorter variable destinationNames.
NetCDF .nc
    .nc - Requests
      for .nc files will always return the data in a table-like, NetCDF-3,
  32-bit, .nc file:
     - Requests
      for .nc files will always return the data in a table-like, NetCDF-3,
  32-bit, .nc file:
  
Don't use NetCDF-Java, NetCDF-C, NetCDF-Fortran, NetCDF-Perl, or Ferret to try to access a remote ERDDAP .nc file. It won't work. Instead, use this approach.
.ncCF
     - Requests for a .ncCF file will return a version 3, 32-bit,
  NetCDF .nc file with the
  Contiguous Ragged Array Representation associated with the dataset's cdm_data_type,
  as defined in the
    CF
  file with the
  Contiguous Ragged Array Representation associated with the dataset's cdm_data_type,
  as defined in the
    CF Discrete Geometries
    Discrete Geometries conventions
  (which were previously named "CF Point Observation Conventions").
 conventions
  (which were previously named "CF Point Observation Conventions").
  
.ncCFHeader
    - Requests
      for .ncCFHeader files will return the header information (text) that
  would be generated if you used
    ncdump -h fileName on the corresponding .ncCF file.
    on the corresponding .ncCF file.
  
.ncCFMA
     - Requests for a .ncCFMA file will return a version 3, 32-bit,
    NetCDF .nc file
   with the Complete or Incomplete, depending on the data, Multidimensional Array Representation
   associated with the dataset's cdm_data_type, as defined in the
     CF
 file
   with the Complete or Incomplete, depending on the data, Multidimensional Array Representation
   associated with the dataset's cdm_data_type, as defined in the
     CF Discrete Sampling Geometries
     Discrete Sampling Geometries conventions, which were previously named "CF Point Observation Conventions".
   This is the file type used by the NODC Templates
   conventions, which were previously named "CF Point Observation Conventions".
   This is the file type used by the NODC Templates .
   A request will succeed only if the dataset has a cdm_data_type other than "Other"
   and if the request includes at least one data variable (not just the outer, descriptive variables).
   The file will include longitude, latitude, time, and other required descriptive variables, even if
   you don't request them.
.
   A request will succeed only if the dataset has a cdm_data_type other than "Other"
   and if the request includes at least one data variable (not just the outer, descriptive variables).
   The file will include longitude, latitude, time, and other required descriptive variables, even if
   you don't request them.
  
.ncCFMAHeader
    - Requests
      for .ncCFMAHeader files will return the header information (text) that
  would be generated if you used
    ncdump -h fileName on the corresponding .ncCFMA file.
    on the corresponding .ncCFMA file.
  
NetCDF-Java, NetCDF-C, NetCDF-Fortran, and NetCDF-Perl -
  Don't try to access an ERDDAP tabledap dataset URL directly with a NetCDF library or tool
  (by treating the tabledap dataset as an OPeNDAP dataset or by creating a URL with the .nc file extension).
  It won't work.
  -
  Don't try to access an ERDDAP tabledap dataset URL directly with a NetCDF library or tool
  (by treating the tabledap dataset as an OPeNDAP dataset or by creating a URL with the .nc file extension).
  It won't work.
    
Fortunately, there is a two step process that does work:
Ocean Data View .odvTxt
   - ODV users can download data in a
    ODV Generic Spreadsheet Format .txt file
 .odvTxt
   - ODV users can download data in a
    ODV Generic Spreadsheet Format .txt file by requesting tabledap's .odvTxt fileType.
  The selected data MUST include longitude, latitude, and time variables.
  Any longitude values (0 to 360, or -180 to 180) are fine.
  After saving the resulting file (with the extension .txt) in your computer:
  by requesting tabledap's .odvTxt fileType.
  The selected data MUST include longitude, latitude, and time variables.
  Any longitude values (0 to 360, or -180 to 180) are fine.
  After saving the resulting file (with the extension .txt) in your computer:
  
OPeNDAP Libraries - Although ERDDAP is an
    OPeNDAP -compatible data server,
    you can't use
  most OPeNDAP client libraries, including
  NetCDF-Java, NetCDF-C, NetCDF-Fortran, NetCDF-Perl
-compatible data server,
    you can't use
  most OPeNDAP client libraries, including
  NetCDF-Java, NetCDF-C, NetCDF-Fortran, NetCDF-Perl ,
  or
  Ferret
,
  or
  Ferret ,
  to get data directly from an ERDDAP tabledap dataset because those libraries don't
  support the OPeNDAP Selection constraints that tabledap datasets use for requesting
  subsets of the dataset, nor do they support the sequence data structure in the response.
  (But see this other approach that works with NetCDF libraries.)
  But you can use the Pydap Client or
  Java-DAP2
,
  to get data directly from an ERDDAP tabledap dataset because those libraries don't
  support the OPeNDAP Selection constraints that tabledap datasets use for requesting
  subsets of the dataset, nor do they support the sequence data structure in the response.
  (But see this other approach that works with NetCDF libraries.)
  But you can use the Pydap Client or
  Java-DAP2 ,
  because they both support Selection
  constraints.  With both the Pydap Client and Java-DAP2, when creating the initial
  connection to an ERDDAP table dataset, use the tabledap dataset's base URL, e.g.,
,
  because they both support Selection
  constraints.  With both the Pydap Client and Java-DAP2, when creating the initial
  connection to an ERDDAP table dataset, use the tabledap dataset's base URL, e.g.,
  
https://coastwatch.pfeg.noaa.gov/erddap/tabledap/pmelTaoDySst
  
Pydap Client users
    can access tabledap datasets via ERDDAP's standard OPeNDAP services.
  See the
    Pydap Client instructions for accessing sequential data
    users
    can access tabledap datasets via ERDDAP's standard OPeNDAP services.
  See the
    Pydap Client instructions for accessing sequential data .
  Note that the name of a dataset in tabledap will always be a single word, e.g.,
pmelTaoDySst
  in the OPeNDAP dataset URL
.
  Note that the name of a dataset in tabledap will always be a single word, e.g.,
pmelTaoDySst
  in the OPeNDAP dataset URL
  
https://coastwatch.pfeg.noaa.gov/erddap/tabledap/pmelTaoDySst
  and won't ever have a file extension (unlike, for example, .cdp for the sample dataset in the
  Pydap instructions).  Also, the name of the sequence in tabledap datasets
  will always be "s"
  (unlike "location" for the sample dataset in the Pydap instructions).
  
Python is
    a widely-used computer language that is very popular among scientists.
    In addition to the Pydap Client,
    you can use Python to download various files from ERDDAP
    as you would download other files from the web:
    is
    a widely-used computer language that is very popular among scientists.
    In addition to the Pydap Client,
    you can use Python to download various files from ERDDAP
    as you would download other files from the web:
import urllib
urllib.urlretrieve("https://baseUrl/erddap/tabledap/datasetID.fileType?query", "outputFileName")
  (You may need to percent encode the query part of the URL.)
  import urllib2
response = urllib2.open("https://baseUrl/erddap/tabledap/datasetID.fileType?query")
theContent = response.read()
  There are other ways to do this in Python. Search the web for more information.
  erddapy (ERDDAP + Python, by Filipe Pires Alvarenga Fernandes) and
    (ERDDAP + Python, by Filipe Pires Alvarenga Fernandes) and
  
erddap-python (by Favio Medrano)
 (by Favio Medrano)
  
are Python libraries that "take advantage of ERDDAP’s RESTful web services and create the
    ERDDAP URL for any request like searching for datasets, acquiring metadata, downloading data, etc."
    They have somewhat different programming styles and slightly different feature sets,
    so it might be good to experiment with both to see which you prefer.
  
"Jupyter Notebook is
      an open-source web application that
      allows you to create and
    share documents that contain live code, equations, visualizations and explanatory text"
    using any of over 40 programming languages, including Python and R.
    Here are two sample Jupyter Notebooks that access ERDDAP using Python:
    ERDDAP Advanced Search Test
      is
      an open-source web application that
      allows you to create and
    share documents that contain live code, equations, visualizations and explanatory text"
    using any of over 40 programming languages, including Python and R.
    Here are two sample Jupyter Notebooks that access ERDDAP using Python:
    ERDDAP Advanced Search Test and
    ERDDAP Timing
 and
    ERDDAP Timing .
    Thanks to Rich Signell.
.
    Thanks to Rich Signell.
  
R Statistical Package -
    R
    is an open source statistical package for many operating systems.
  In R, you can download a .csv file from ERDDAP
    and then import data from that .csv file
  into an R structure (e.g., test).  For example:
 -
    R
    is an open source statistical package for many operating systems.
  In R, you can download a .csv file from ERDDAP
    and then import data from that .csv file
  into an R structure (e.g., test).  For example:
download.file(url="https://coastwatch.pfeg.noaa.gov/erddap/tabledap/pmelTaoDySst.csv?longitude,latitude,time,station,wmo_platform_code,T_25&time>=2015-05-23T12:00:00Z&time<=2015-05-31T12:00:00Z", destfile="/home/bsimons/test.csv") test<-read.csv(file="/home/bsimons/test.csv")(You may need to percent encode the query part of the URL.)
There are third-party R packages designed to make it easier to work with ERDDAP from within R:
    rerddap ,
    rerddapXtracto
,
    rerddapXtracto , and
    plotdap
, and
    plotdap .
  Thanks to 
  rOpenSci
.
  Thanks to 
  rOpenSci and Roy Mendelssohn.
  and Roy Mendelssohn.
  
.wav -
    ERDDAP can return data in .wav files,
    which are uncompressed audio files.
 -
    ERDDAP can return data in .wav files,
    which are uncompressed audio files.
  
 digitized sound waves.
    We do not recommend saving other types of data in .wav files.
 digitized sound waves.
    We do not recommend saving other types of data in .wav files.
  Making an Image File with a Graph or Map of Tabular Data If a tabledap request URL specifies a subset of data which is suitable for making a graph or a map, and the fileType is an image fileType, tabledap will return an image with a graph or map. tabledap request URLs can include optional graphics commands which let you customize the graph or map. As with other tabledap request URLs, you can create these URLs by hand or have a computer program do it. Or, you can use the Make A Graph web pages, which simplify creating these URLs (see the "graph" links in the table of tabledap datasets).
The fileType options for downloading images of graphs and maps of table data are:
| Image fileTypes | Description | Info | Example | 
|---|---|---|---|
| .kml | View a .kml file, suitable for Google Earth. | info  | example | 
| .smallPdf | View a small .pdf image file with a graph or map. | info  | example | 
| View a standard, medium-sized .pdf image file with a graph or map. | info  | example | |
| .largePdf | View a large .pdf image file with a graph or map. | info  | example | 
| .smallPng | View a small .png image file with a graph or map. | info  | example | 
| .png | View a standard, medium-sized .png image file with a graph or map. | info  | example | 
| .largePng | View a large .png image file with a graph or map. | info  | example | 
| .transparentPng | View a .png image file (just the data, without axes, landmask, or legend). | info  | example | 
Image Size - ".small" and ".large" were ERDDAP's original system for making different-sized images. Now, for .png and .transparentPng images (not other image file types), you can also use the &.size=width|height parameter to request an image of any size.
.transparentPng - The .transparentPng file type will make a graph or map without the graph axes, landmask, or legend, and with a transparent (not opaque white) background. This file type can be used for any type of graph or map. For graphs and maps, the default size is 360x360 pixels. Or, you can use the &.size=width|height parameter to request an image of any size.
Incompatibilities
  
Some results file types have restrictions. For example, Google Earth .kml is only
  appropriate for results with longitude and latitude values. If a given request is
  incompatible with the requested file type, tabledap throws an error.
Command Line Downloads with curl
If you want to download a series of files from ERDDAP, you don't have to request each file's
ERDDAP URL in your browser, sitting and waiting for each file to download.
If you are comfortable writing computer programs (e.g., with C, Java, Python, Matlab, r)
or scripts (e.g., Python, bash, tcsh, PowerShell, or Windows batch files),
you can write a program or script with a loop (or a series of commands)
that imports all of the desired data files.
Or, if you are comfortable running command line programs
(from a Linux or Windows command line, or a Mac OS Terminal), you can use curl (or a similar program like
  wget )
to save results files from ERDDAP into files on your hard drive,
without using a browser or writing a computer program or script.
)
to save results files from ERDDAP into files on your hard drive,
without using a browser or writing a computer program or script.
ERDDAP + curl is amazingly powerful and allows you to use ERDDAP in many new ways.
On Linux and Mac OS X, curl is probably already installed.
On Mac OS X, to get to a command line, use "Finder : Go : Utilities : Terminal".
On Windows, you need to
  download curl (the "Windows 64 - binary, the curl project" variant worked for me on Windows 10)
  and install it.
  (the "Windows 64 - binary, the curl project" variant worked for me on Windows 10)
  and install it.
On Windows, to get to a command line, click on "Start" and type
"cmd" into the search text field.
Please be kind to other ERDDAP users: run just one script or curl command at a time.
Instructions for using curl are on the 
curl man page and in this
curl tutorial
 and in this
curl tutorial .
.
But here is a quick tutorial related to using curl with ERDDAP:
curl --compressed -g "https://coastwatch.pfeg.noaa.gov/erddap/tabledap/cwwcNDBCMet.png?time,atmp&time%3E=2010-09-03T00:00:00Z&time%3C=2010-09-06T00:00:00Z&station=%22TAML1%22&.draw=linesAndMarkers&.marker=5|5&.color=0x000000&.colorBar=|||||" -o NDBCatmpTAML1.pngIn curl, as in many other programs, the query part of the erddapUrl must be percent encoded
 .  To do this, you need to convert
  special characters (other than the initial '&' and the main '=') in all constraints
  into the form %HH, where HH is the 2 digit hexadecimal value of the character.
  Usually, you just need to convert a few of the punctuation characters: % into %25,
  & into %26, " into %22, < into %3C, = into %3D, > into %3E, + into %2B, | into %7C,
  space into %20, [ into %5B, ] into %5D,
  and convert all characters above #127 into their UTF-8 bytes and then percent encode
  each byte of the UTF-8 form into the %HH format (ask a programmer for help).
  For example, &stationID>="41004"
  becomes &stationID%3E=%2241004%22
  Note that percent encoding is generally required when you access ERDDAP via
  software other than a browser. Browsers usually handle percent encoding for you.
  In some situations, you need to percent encode all characters other than
  A-Za-z0-9_-!.~'()* .
  Programming languages have tools to do this (for example, see Java's
  java.net.URLEncoder
.  To do this, you need to convert
  special characters (other than the initial '&' and the main '=') in all constraints
  into the form %HH, where HH is the 2 digit hexadecimal value of the character.
  Usually, you just need to convert a few of the punctuation characters: % into %25,
  & into %26, " into %22, < into %3C, = into %3D, > into %3E, + into %2B, | into %7C,
  space into %20, [ into %5B, ] into %5D,
  and convert all characters above #127 into their UTF-8 bytes and then percent encode
  each byte of the UTF-8 form into the %HH format (ask a programmer for help).
  For example, &stationID>="41004"
  becomes &stationID%3E=%2241004%22
  Note that percent encoding is generally required when you access ERDDAP via
  software other than a browser. Browsers usually handle percent encoding for you.
  In some situations, you need to percent encode all characters other than
  A-Za-z0-9_-!.~'()* .
  Programming languages have tools to do this (for example, see Java's
  java.net.URLEncoder and JavaScript's
encodeURIComponent()
     and JavaScript's
encodeURIComponent() ) and there are
  websites that percent encode/decode for you
) and there are
  websites that percent encode/decode for you .
.
   them in the erddapURL as %5B, %5D, %7B, %7D, respectively.
  Fortunately, these are rare in tabledap URLs.
  Then, in the erddapUrl, replace a zero-padded number (for example 01) with a range
  of values (for example, [01-15] ),
  or replace a substring (for example TAML1) with a list of values (for example,
  {TAML1,41009,46088} ).
  The #1 within the output fileName causes the current value of the range or list
  to be put into the output fileName.
  For example,
 
them in the erddapURL as %5B, %5D, %7B, %7D, respectively.
  Fortunately, these are rare in tabledap URLs.
  Then, in the erddapUrl, replace a zero-padded number (for example 01) with a range
  of values (for example, [01-15] ),
  or replace a substring (for example TAML1) with a list of values (for example,
  {TAML1,41009,46088} ).
  The #1 within the output fileName causes the current value of the range or list
  to be put into the output fileName.
  For example, 
curl --compressed "https://coastwatch.pfeg.noaa.gov/erddap/tabledap/cwwcNDBCMet.png?time,atmp&time%3E=2010-09-03T00:00:00Z&time%3C=2010-09-06T00:00:00Z&station=%22TAML1%22&.draw=linesAndMarkers&.marker=5|5&.color=0x000000&.colorBar=|||||" -o NDBCatmp#1.png(That example includes --compressed because it is a generally useful option, but there is little benefit to --compressed when requesting .png files because they are already compressed internally.)
curl -v --data 'user=myUserName&password=myPassword' -c cookies.txt -b cookies.txt -k https://baseurl:8443/erddap/login.html
curl --compressed -v -c cookies.txt -b cookies.txt -k https://baseurl:8443/erddap/tabledap/datasetID.fileType?query -o outputFileName
 DAP
   DAP selection constraint
  selection constraint query  in the form: {resultsVariables}{constraints} .
   For example,
 query  in the form: {resultsVariables}{constraints} .
   For example,
   DAP
       DAP selection constraints
      selection constraints ,
      but with a few additional features.
,
      but with a few additional features.
     :
        special characters in the query values (the parts after the '=' signs) are encoded as %HH, where
        HH is the 2 digit hexadecimal value of the character (for example, ' ' is replaced with "%20").
        Characters above #127 must be converted to UTF-8 bytes, then each UTF-8 byte must be
        percent encoded. Normally, when you use a browser, the browser takes care of this for you.
        But if your computer program or script generates the URLs, it probably needs to do the
        percent encoding itself.  If so, you need to encode all characters other than A-Za-z0-9_-!.~'()*
        in all query values. Programming languages have tools to do this (for example, see Java's
java.net.URLEncoder
:
        special characters in the query values (the parts after the '=' signs) are encoded as %HH, where
        HH is the 2 digit hexadecimal value of the character (for example, ' ' is replaced with "%20").
        Characters above #127 must be converted to UTF-8 bytes, then each UTF-8 byte must be
        percent encoded. Normally, when you use a browser, the browser takes care of this for you.
        But if your computer program or script generates the URLs, it probably needs to do the
        percent encoding itself.  If so, you need to encode all characters other than A-Za-z0-9_-!.~'()*
        in all query values. Programming languages have tools to do this (for example, see Java's
java.net.URLEncoder and JavaScript's
encodeURIComponent()
 and JavaScript's
encodeURIComponent() ) and there are
       websites that percent encode/decode for you
) and there are
       websites that percent encode/decode for you .
.
       .
          When ERDDAP performs these tests, it allows for minor variations and tries
          to avoid the problem. But it is possible that some datasets will still
          have problems with these queries and return unexpected and incorrect results.
.
          When ERDDAP performs these tests, it allows for minor variations and tries
          to avoid the problem. But it is possible that some datasets will still
          have problems with these queries and return unexpected and incorrect results.
       -
          Many
          numeric variables have an attribute which identifies a
          number (e.g., -99) as a missing_value or a _FillValue. When ERDDAP tests
          constraints, it always treats these values as NaN's. So:
 -
          Many
          numeric variables have an attribute which identifies a
          number (e.g., -99) as a missing_value or a _FillValue. When ERDDAP tests
          constraints, it always treats these values as NaN's. So:
           on the right.
         on the right.
         (tutorial
             (tutorial ) as is used by Java.
) as is used by Java.
         (e.g., 2002-08-03T12:30:00Z, but some time variables in some datasets include
      milliseconds, e.g., 2002-08-03T12:30:00.123Z).
      (e.g., 2002-08-03T12:30:00Z, but some time variables in some datasets include
      milliseconds, e.g., 2002-08-03T12:30:00.123Z).
      Without orderBy, the rows of data in the response table are in the order they arrived from the data source, which may or may not be a nice logical order. Thus, orderBy allows you to request that the results table be sorted in a specific way. For example, use the query
?stationID,time,temperature&time>2025-10-18&orderBy("stationID,time")
      to get the results sorted by stationID, then time.
      Or use the query
      ?stationID,time,temperature&time>2025-10-18&orderBy("time,stationID")
      to get the results sorted by time first, then stationID.
      orderBy() doesn't support
      the divisor options for numeric variables, i.e.,
      
numericVariable[/number[timeUnits][:offset]]
      
because they would be nonsensical.
    
For orderByClosest, for each group, ERDDAP will return just the row where the value of the last CSV variable is closest to the divisor (interval). For example,
?stationID,time,temperature&time>2025-10-18&orderByClosest("stationID,time/2hours")
      will sort by stationID and time, but only return the rows for each stationID where
      the last orderBy column (time) are closest to 2hour intervals (12am, 2am, 4am, ...).
      For numeric variables in orderByMax CSV list, for each group,
      ERDDAP will return the exact value (e.g., the exact time) at
      which the closest value occurred.
      This is the closest thing in tabledap to stride values in a griddap request.
      For orderByCount, for each group, ERDDAP will return just one row with the count of the number of non-NaN values for each variable not in the CSV list. For example, use the query
?stationID,time,temperature,windspeed&time>2025-10-18&orderByCount("stationID,time/1day")
      to get a count of the number of non-NaN temperature and windspeed values for each stationID, for each day
      (for stations with data from after 2025-10-18).
      Divisors - All orderBy options
      (other than the plain orderBy() and orderByClosest()) support
      divisor options for any of the numeric variables in the orderBy... CSV list, in the form
      
numericVariable[/number[timeUnits][:offset]]
      
Some examples are: time/10, time/2days, depth/10, depth/0.5, depth/10:5.
      
For orderByLimit, the last value in the CSV list must be the limit number (e.g., 10). Within each sort group, only the first 'limit' rows will be kept. For example,
?stationID,time,temperature&time>2025-10-18&orderByLimit("stationID,time/1day,10")
      will sort by stationID and time, but only return the first 10 rows for each stationID per day.
      This will usually return the same rows as the first n rows per group of a similar
      request with no orderByLimit, but not always.
      This is similar to SQL's LIMIT clause.
      orderByMax will sort results into groups based on values of the variables in the CSV list except the last variable, then just keep the row within each group where the last CSV list variable has the highest value. (If there are two or more rows which have the same highest value, ERDDAP may return any of them.) For example, use the query
?stationID,time,temperature&time>2025-10-18&orderByMax("stationID,time/1day,temperature")
      to get just the rows of data with each station's maximum
      temperature value for each day (for stations
      with data from after 2025-10-18).
      For numeric variables in orderByMax CSV list, for each group,
      ERDDAP will return the exact value (e.g., the exact time) at
      which the max value (e.g., temperature) occurred.
      This is the closest thing in tabledap to griddap's allowing requests for the [last]
      axis value.
      ?stationID,time,temperature&time>2025-10-18&orderByMinMax("stationID,time/1day,temperature")
      to get just the rows of data with each station's minimum temperature value and each station's
      maximum time value for each day (for stations with data from after 2025-10-18).
      If there is only one row of data for a given combination (e.g., stationID), there will
      still be two rows in the output (with identical data).
      For orderByMean, for each group, ERDDAP will return the mean of each of the variables not in the CSV list. You can use the same divisor options as other orderBy options (e.g., time/1day or depth/10). For example,
?stationID,time,temperature&time>2025-10-18&orderByMean("stationID,time/1day")
      will sort by stationID and time, but only return the mean temperature value for each stationID for each day.
      For orderBySum, for each group, ERDDAP will return the sum of each of the variables not in the CSV list. You can use the same divisor options as other orderBy options (e.g., time/1day or depth/10). For example,
?stationID,time,rainfall&time>2025-10-18&orderBySum("stationID,time/1day")
      will sort by stationID and time, but only return the sum of rainfall values for each stationID for each day.
       standard (for example, degree_C).
 standard (for example, degree_C).
       standard (for example, Cel).
 standard (for example, Cel).
      Or, if you change the fileType in the URL from .png to .graph,
    you can see a Make A Graph web page with that request loaded:
    
https://coastwatch.pfeg.noaa.gov/erddap/tabledap/pmelTaoDySst.graph?time,T_25&station="0n0e"&time>=2015-05-23T12:00:00Z&time<=2015-05-31T12:00:00Z&.draw=lines
    
That makes it easy for humans to modify an image request to make a
    similar graph or map.
    
Or, if you change the fileType in the URL from .png to a data fileType
    (e.g., .htmlTable), you can view or download the data that was graphed:
    
https://coastwatch.pfeg.noaa.gov/erddap/tabledap/pmelTaoDySst.htmlTable?time,T_25&station="0n0e"&time>=2015-05-23T12:00:00Z&time<=2015-05-31T12:00:00Z&.draw=lines
    
A sample URL to view a .png of a map is 
    
https://coastwatch.pfeg.noaa.gov/erddap/tabledap/pmelTaoDySst.png?longitude,latitude,T_25&time=2015-05-31T12:00:00Z&.draw=markers&.marker=5|5
    
Or, if you change the fileType in the URL from .png to .graph,
    you can see a Make A Graph web page with that request loaded:
    
https://coastwatch.pfeg.noaa.gov/erddap/tabledap/pmelTaoDySst.graph?longitude,latitude,T_25&time=2015-05-31T12:00:00Z&.draw=markers&.marker=5|5
    
Or, if you change the fileType in the URL from .png to a data fileType
    (e.g., .htmlTable), you can view or download the data that was mapped:
    
https://coastwatch.pfeg.noaa.gov/erddap/tabledap/pmelTaoDySst.htmlTable?longitude,latitude,T_25&time=2015-05-31T12:00:00Z&.draw=markers&.marker=5|5
Some ERDDAP installations do have authentication enabled. Currently, ERDDAP only supports authentication via Google-managed email accounts, which includes email accounts at NOAA and many universities. If an ERDDAP has authentication enabled, anyone with a Google-managed email account can log in, but they will only have access to the private datasets that the ERDDAP administrator has explicitly authorized them to access. For instructions on logging into ERDDAP from a browser or via a script, see Access to Private Datasets in ERDDAP.
 in the HTTP GET request header sent
by the client.  If a supported compression type (gzip, x-gzip, or deflate) is found
in the accept-encoding list, ERDDAP includes "content‑encoding" in the HTTP response
header and compresses the data as it transmits it.
It is up to the client program to look for content-encoding and decompress the data accordingly.
Requesting compression is optional, but compressed responses are often 3-10 times faster,
so this is a big time savings if you are downloading lots of large files.
(Note that there is no benefit
to requesting compressed .png files since the files' contents are already compressed.)
in the HTTP GET request header sent
by the client.  If a supported compression type (gzip, x-gzip, or deflate) is found
in the accept-encoding list, ERDDAP includes "content‑encoding" in the HTTP response
header and compresses the data as it transmits it.
It is up to the client program to look for content-encoding and decompress the data accordingly.
Requesting compression is optional, but compressed responses are often 3-10 times faster,
so this is a big time savings if you are downloading lots of large files.
(Note that there is no benefit
to requesting compressed .png files since the files' contents are already compressed.)
 .
.
   (although you should either handle deflate'd responses or not request deflate).
  (although you should either handle deflate'd responses or not request deflate).
To generate a citation for a dataset:
If you think of the dataset as a scientific article, you can generate a 
citation based on the author (see the "creator_name" or "institution" metadata),
the date that you downloaded the data, the title (see the "title" metadata),
and the publisher (see the "publisher_name" metadata).
If possible, please include the specific URL(s) used to download the data.
If the dataset's metadata includes a
Digital Object Identifier (DOI) , please
include that in the citation you create.
, please
include that in the citation you create.
 
If the error response was generated by ERDDAP (not by some other part of the Internet,
  e.g., Tomcat, Apache, routers, or your browser),
  it will come with an (OPeN)DAPv2.0-formatted, plain text, UTF-8-encoded error message
  as the payload of the response, e.g.,
Error {
    code=404;
    message="Not Found: Your query produced no matching results.
(time>=2019-03-27T00:00:00Z is outside of the variable's actual_range: 1970-02-26T20:00:00Z to 2019-03-26T15:00:00Z)";
}
Notes:
Or, you can join the ERDDAP Google Group / Mailing List by visiting
https://groups.google.com/forum/#!forum/erddap and clicking on "Apply for membership". 
Once you are a member, you can post your question there or search to see if the question
has already been asked and answered.
 
and clicking on "Apply for membership". 
Once you are a member, you can post your question there or search to see if the question
has already been asked and answered.