Skip to main content

The python version of "moment" which is made with reference to "moment.js"

Project description

pymoment

The python version of "moment" which is made with reference to "moment.js"

To install pymoment, please download the whl file, then install with the pip command:

pip install pymoment-*.whl

or just install:

pip install pymoment

Then import the package for your code:

from moment import moment

Parameter for Constructor Code Notes
None moment() Get the current date and time
moment moment(m) Create a new moment object with the moment object "m"
datetime.datetime moment(d) Create a moment object with the datetime object "d"
str moment('2021-04-12') Parsing the string to a moment object
list moment([2021, 4, 12]) Parsing the list to a moment object

Parse

Now

now = moment()

now = moment([])

now = moment(datetime.datetime.now())

String

moment(String)

You can create a moment from a string. The following are examples of strings in supported formats.

2013-02-08 # Date only

2013-02-08T09 # An hour time part separated by a T

2013-02-08 09 # An hour time part separated by a space

2013-02-08 09:30 # An hour and minute time part

2013-02-08 09:30:26 # An hour, minute, and second time part

2013-02-08 09:30:26.123 # An hour, minute, second, and millisecond time part

20130208T080910,123 # Short date and time up to ms, separated by comma

20130208T080910.123 # Short date and time up to ms

20130208T080910 # Short date and time up to seconds

20130208T0809 # Short date and time up to minutes

20130208T08 # Short date and time, hours only

20130208 # Short date only

With time zone:

2021-04-22 04:02:09.957000 +0800

2021-04-22 04:02:09 +0800

2021-04-22 04:02 +0800

2021-04-22 04 +0800

20210422 04:02:09 +0800

List

moment([2021, 4, 12])

You can create a moment with a list of numbers that mirror the parameters passed to datetime.

[ year, month=1, day=1, hour=0, minute=0, second=0, microsecond=0 ]

Any parameter except "year" will default to the lowest possible number.

moment([2010]) # January 1st

moment([2010, 6]) # July 1st

moment([2010, 6, 10]) # July 10th

If an empty list is passed, you could get the current date time.

moment([])

Display

Once parsing and manipulation are done, you need some way to display the moment.

Format

This is the most robust display option. It takes a string of tokens and replaces them with their corresponding values.

moment().format()

moment().format(String)

Token Output
Month M 1 2 ... 11 12
Mo 1st 2nd ... 11th 12th
MM 01 02 ... 11 12
MMM Jan Feb ... Nov Dec
MMMM January February ... November December
Quarter Q 1 2 3 4
Qo 1st 2nd 3rd 4th
Day of Month D 1 2 ... 30 31
Do 1st 2nd ... 30th 31st
DD 01 02 ... 30 31
Day of Year DDD 1 2 ... 364 365
DDDo 1st 2nd ... 364th 365th
DDDD 001 002 ... 364 365
Day of Week d 0 1 ... 5 6
do 0th 1st ... 5th 6th
dd Su Mo ... Fr Sa
ddd Sun Mon ... Fri Sat
dddd Sunday Monday ... Friday Saturday
Day of Week (ISO) E 1 2 ... 6 7
Week of Year w 1 2 ... 52 53
wo 1st 2nd ... 52nd 53rd
ww 01 02 ... 52 53
Week of Year (ISO) W 1 2 ... 52 53
Wo 1st 2nd ... 52nd 53rd
WW 01 02 ... 52 53
Year YY 70 71 ... 29 30
YYYY 1970 1971 ... 2029 2030
AM/PM A AM PM
a am pm
Hour H 0 1 ... 22 23
HH 00 01 ... 22 23
h 1 2 ... 11 12
hh 01 02 ... 11 12
k 1 2 ... 23 24
kk 01 02 ... 23 24
Minute m 0 1 ... 58 59
mm 00 01 ... 58 59
Second s 0 1 ... 58 59
ss 00 01 ... 58 59
Fractional Second S 0 1 ... 8 9
SS 00 01 ... 98 99
SSS 000 001 ... 998 999
SSSS 0000 0001 ... 9998 9999
SSSSS 00000 00001 ... 99998 99999
SSSSSS 000000 000001 ... 999998 999999
Time Zone Z -07:00 -06:00 ... +06:00 +07:00
ZZ -0700 -0600 ... +0600 +0700
Unix Timestamp X 1360013296
Unix Millisecond Timestamp x 1360013296123
Time LT 8:30 PM
Time with seconds LTS 8:30:25 PM
Month numeral, day of month, year L 09/04/1986
l 9/4/1986
Month name, day of month, year LL September 4, 1986
ll Sep 4, 1986
Month name, day of month, year, time LLL September 4, 1986 8:30 PM
lll Sep 4, 1986 8:30 PM
Month name, day of month, day of week, year, time LLLL Thursday, September 4, 1986 8:30 PM
llll Thu, Sep 4, 1986 8:30 PM

Escaping characters

To escape characters in format strings, you can wrap the characters in square brackets.

moment('2021-04-22 04:02:09.957000 +0800').format('[Today is] dddd.')

'Today is Thursday.'

Get + Set

Calling all methods without parameters acts as a getter, and calling them with a parameter acts as a setter.

Millisecond

moment().millisecond(Number)

moment().millisecond() # Number

moment().milliseconds(Number)

moment().milliseconds() # Number

Gets or sets the milliseconds.

Accepts numbers from 0 to 999. If the range is exceeded, it will bubble up to the seconds.

Second

moment().second(Number)

moment().second() # Number

moment().seconds(Number)

moment().seconds() # Number

Gets or sets the seconds.

Accepts numbers from 0 to 59. If the range is exceeded, it will bubble up to the minutes.

Minutes

moment().minute(Number)

moment().minute() # Number

moment().minutes(Number)

moment().minutes() # Number

Gets or sets the minutes.

Accepts numbers from 0 to 59. If the range is exceeded, it will bubble up to the hour.

Hour

moment().hour(Number)

moment().hour() # Number

moment().hours(Number)

moment().hours() # Number

Gets or sets the hour.

Accepts numbers from 0 to 23. If the range is exceeded, it will bubble up to the day.

Date of Month

moment().date(Number)

moment().date() # Number

moment().dates(Number)

moment().dates() # Number

Gets or sets the day of the month.

Accepts numbers from 1 to 31. If the range is exceeded, it will bubble up to the months.

Note: moment.date is for the date of the month, and moment.day is for the day of the week.

Day of Week

moment().day(Number)

moment().day() # Number

moment().days(Number)

moment().days() # Number

Gets or sets the day of the week.

This method can be used to set the day of the week, with Sunday as 0 and Saturday as 6.

If the value given is from 0 to 6, the resulting date will be within the current (Sunday-to-Saturday) week.

If the range is exceeded, it will bubble up to other weeks.

Note: moment.date is for the date of the month, and moment.day is for the day of the week.

Day of Week (Locale Aware)

moment().weekday(Number)

moment().weekday() # Number

moment().weekday(Number)

moment().weekday() # Number

Gets or sets the day of the week according to the locale.

If the locale assigns Monday as the first day of the week, moment().weekday(0) will be Monday. If Sunday is the first day of the week, moment().weekday(0) will be Sunday.

Day of Week (Locale Aware)

moment().isoWeekday(Number) moment().isoWeekday() # Number

Gets or sets the ISO day of the week with 1 being Monday and 7 being Sunday.

As with moment#day, if the range is exceeded, it will bubble up to other weeks.

Day of Year

moment().dayOfYear(Number)

moment().dayOfYear() # Number

Gets or sets the day of the year.

Accepts numbers from 1 to 366. If the range is exceeded, it will bubble up to the years.

Week of Year

moment().week(Number)

moment().week() # Number

moment().weeks(Number)

moment().weeks() # Number

Gets or sets the week of the year.

Because different locales define week of year numbering differently, use moment.local to set the localized week of the year.

The week of the year varies depending on which day is the first day of the week (Sunday, Monday, etc), and which week is the first week of the year.

For example, in the United States, Sunday is the first day of the week. The week with January 1st in it is the first week of the year.

In France, Monday is the first day of the week, and the week with January 4th is the first week of the year.

The output of moment.week will depend on the locale for that moment.

When setting the week of the year, the day of the week is retained.

Week of Year (ISO)

moment().isoWeek(Number)

moment().isoWeek() # Number

moment().isoWeeks(Number)

moment().isoWeeks() # Number

Gets or sets the ISO week of the year.

When setting the week of the year, the day of the week is retained.

Month

moment().month(Number)

moment().month() # Number

moment().months(Number)

moment().months() # Number

Gets or sets the month.

Accepts numbers from 0 to 11. If the range is exceeded, it will bubble up to the year.

Note: Months are zero indexed, so January is month 0.

Quarter

moment().quarter() # Number

moment().quarter(Number)

moment().quarters() # Number

moment().quarters(Number)

Gets the quarter (1 to 4) and sets the quarter with parameter Number.

If the range is exceeded, it will bubble up to other quarters.

Year

moment().year(Number)

moment().year() # Number

moment().years(Number)

moment().years() # Number

Gets or sets the year. According to datetime.MINYEAR, parameter Number should larger than zero.

Weeks In Year

moment().weeksInYear()

Gets the number of weeks according to locale in the current moment's year.

Weeks In Year (ISO)

moment().isoWeeksInYear()

Gets the number of weeks in the current moment's year, according to ISO weeks.

Manipulate

Add

moment().add(Number, String, inplace=False)

Mutates the original moment by adding time and return a new moment instance as a result.

This is a pretty robust function for adding time to an existing moment. To add time, pass the key of what time you want to add, and the amount you want to add.

moment().add(7, 'days')

There are some shorthand keys as well if you're into that whole brevity thing.

moment().add(7, 'd')

If inplace is True, the original moment instance should be updated by the adding operation.

Key Shorthand
years y
quarters Q
months M
weeks w
days d
hours h
minutes m
seconds s
milliseconds ms

If the day of the month on the original date is greater than the number of days in the final month, the day of the month will change to the last day in the final month.

moment('2010-01-31').add(1, 'months') # 2010-02-28

When decimal values are passed for days and months, they are rounded to the nearest integer. Weeks, quarters, and years are converted to days or months, and then rounded to the nearest integer.

moment('2010-01-31').add(1.5, 'months') == moment('2010-01-31').add(2, 'months')

moment('2010-01-31').add(.7, 'years') == moment('2010-01-31').add(8, 'months') # .7*12 = 8.4, rounded to 8

Subtract

moment().subtract(Number, String, inplace=False)

Mutates the original moment by subtracting time and return a new moment instance as a result.

This is exactly the same as moment().add, only instead of adding time, it subtracts time.

moment().subtract(7, 'days')

If inplace is True, the original moment instance should be updated by the subtracting operation.

Start of Time

moment().startOf(String, inplace=False)

Mutates the original moment by setting it to the start of a unit of time.

If inplace is True, the original moment instance should be updated to the start of a unit of time.

moment().startOf('year') # set to January 1st, 12:00 am this year

moment().startOf('month') # set to the first of this month, 12:00 am

moment().startOf('quarter') # set to the beginning of the current quarter, 1st day of months, 12:00 am

moment().startOf('week') # set to the first day of this week, 12:00 am

moment().startOf('isoWeek') # set to the first day of this week according to ISO 8601, 12:00 am

moment().startOf('day') # set to 12:00 am today

moment().startOf('date') # set to 12:00 am today

moment().startOf('hour') # set to now, but with 0 mins, 0 secs, and 0 ms

moment().startOf('minute') # set to now, but with 0 seconds and 0 milliseconds

moment().startOf('second') # same as moment().milliseconds(0)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

pymoment-0.0.4-py3-none-any.whl (10.5 kB view details)

Uploaded Python 3

File details

Details for the file pymoment-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: pymoment-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 10.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.7.3

File hashes

Hashes for pymoment-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 11c0423fe16c910cd4ae6ed3fa4f6c09efc195594e3de9f4333088e4bd4b4a42
MD5 a129a4ace32e89b2021808961ce683bc
BLAKE2b-256 7b937a26861996c7e47e9bb0925a6594050bbfd83bf76d1b099f4ccb6b3e8b50

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page