CronParser 1.3.0
dotnet add package CronParser --version 1.3.0
NuGet\Install-Package CronParser -Version 1.3.0
<PackageReference Include="CronParser" Version="1.3.0" />
<PackageVersion Include="CronParser" Version="1.3.0" />
<PackageReference Include="CronParser" />
paket add CronParser --version 1.3.0
#r "nuget: CronParser, 1.3.0"
#addin nuget:?package=CronParser&version=1.3.0
#tool nuget:?package=CronParser&version=1.3.0
<p align="center">English | <a href="./README.zh.md">中文</a> </p>
CronParser
Package | NuGet Stable | Downloads |
---|---|---|
CronParser |
Introduction
CronParser
is a C# library designed to parse Cron expressions. It can convert a Cron expression string into a CronExpression
object, supporting 5 - part (from minutes to days of the week), 6 - part (from seconds to days of the week), and 7 - part (from seconds to years) Cron expressions.
Features
- Flexible Parsing: Supports Cron expressions of different lengths.
- Input Validation: Rigorously validates the input Cron expression to ensure its validity.
- Error Handling: Catches and handles potential errors during the parsing process, enhancing the robustness of the code.
The corn expression version supported by this library are following:
Five-part format
* * * * *
- - - - -
| | | | |
| | | | |
| | | | +----- Day of week(Range:0-6 or SUN-SAT)
| | | +------- Month(Range: 1-12 or JAN-DEC)
| | +--------- Day of month(Range:1-31)
| +----------- Hour(Range:0-23)
+------------- Minute(Range:0-59)
Six-part format(include second)
* * * * * *
- - - - - -
| | | | | |
| | | | | |
| | | | | +--- Day of week
| | | | +----- Month
| | | +------- Day of month
| | +--------- Hour
| +----------- Minute
+------------- Second(Range:0-59)
Seven-part format
* * * * * * *
- - - - - - -
| | | | | | |
| | | | | | |
| | | | | | +--- Year
| | | | | +----- Day of week
| | | | +------- Month
| | | +--------- Day of month
| | +----------- Hour
| +------------- Minute
+--------------- Second
Cron expression
Field | Required | Allowed values | Allowed special characters | Remarks |
---|---|---|---|---|
Second | No | 0-59 | * , - ,/ |
* stands every second <br>3-10 specifies the seconds from 3 to 10.<br>5/15 specifies the seconds: 5,20,35,50<br>3,5,7 specifies the seconds: 3,5,7 |
Minute | Yes | 0–59 | * , - ,/ |
Similar with above. |
Hour | Yes | 0–23 | * , - ,/ |
Similar with above. |
Day of month | Yes | 1–31 | * , - L |
L specifies the last day of the month. |
Month | Yes | 1–12 or JAN–DEC | * , - / |
Similar with second second. |
Day of week | Yes | 0–6 or SUN–SAT | * , - / L # |
5L specifies the last Friday.<br> 5#3 specifies the third Friday of the month. |
Year | No | 1970–2099 | * , - / |
Similar with second. |
DateTimeOffset time = new DateTimeOffset(2025, 1, 1, 0, 0, 0, TimeSpan.Zero);
var cronExpression = CronExpressionParser.Parse("0 * * * * *");
var nextTime = cronExpression.GetNextAvaliableTime(time);
Console.WriteLine(nextTime.ToString("yyyy-MM-dd HH:mm:ss"));//2025-01-01 00:01:00
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
- Cron Wiki for more information on cron expressions.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.