This library provides a simple class DateTimeClass
for sync system timestamp vis ntp and a struct DateFormatter
to format date time to string, works on ESP8266 and ESP32 platform.
This libarary is published to PlatformIO, PlatformIO IDE has built-in PIO Home: Library Manager, you can search ESPDateTime
in Library Manager and click to install this library.
Or you can install using platformio cli:
# Using library Id
platformio lib install 6871
# or Using library Name
pio lib install "mcxiaoke/ESPDateTime@^1.0.4"
Add dependency to your platformio.ini
file:
lib_deps =
# Using library Name
mcxiaoke/ESPDateTime @ ^1.0.4
# or You can use the latest git version
https://github.com/mcxiaoke/ESPDateTime.git
I will publish this library to Arduino Library soon. (TODO)
Clone this repo or download source code at release page, then copy all files in src to your project source directory.
#include <ESPDateTime.h>
DateTime
is a global DateTimeClass
object for use in your code.
You can pick TimeZone
name from here: TZ.h or here: DateTimeTZ.h
void setupDateTime() {
// setup this after wifi connected
// you can use custom timeZone,server and timeout
// DateTime.setTimeZone("CST-8");
// DateTime.setServer("asia.pool.ntp.org");
// DateTime.begin(15 * 1000);
// from
/** changed from 0.2.x **/
DateTime.setTimeZone("CST-8");
// this method config ntp and wait for time sync
// default timeout is 10 seconds
DateTime.begin(/* timeout param */);
if (!DateTime.isTimeValid()) {
Serial.println("Failed to get time from server.");
}
}
You can use DateTime
to get current time and format time to string, format
function internal using strftime
function in <time.h>
.
// alias for getTime()
time_t DateTime.now()
// get current timestap in seconds
time_t DateTime.getTime()
// get current timezone
char* DateTime.getTimeZone()
// get formatted string of time
String DateTime.toString()
// get formatted string of utc time
String DateTime.toUTCString()
// format local time to string, using strftime
// http://www.cplusplus.com/reference/ctime/strftime/
String DateTime.format(const char* fmt);
// format utc time to string, using strftime
// http://www.cplusplus.com/reference/ctime/strftime/
String DateTime.formatUTC(const char* fmt);
- DateTimeClass - Main Class for get current timestamp and format time to string, class of global
DateTime
object. - DateTimeParts - Struct for get year/month/day/week part of time struct.
- DateFormatter - Class for format timestamp to string, include some format constants.
- TimeElapsed - Class for calculate elapsed time in milliseconds, original code is from elapsedMillis.
See examples folder in this project, to run example on your device, WiFi ssid and password must be set in source code.
See API Reference.
Copyright 2019-2021 github@mcxiaoke.com
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.