从数字中获取月份名称



如何从月份编号中获取月份名称?

例如,如果我有3,我想返回march

date.tm_month()

如何获取字符串march

import datetime
mydate = datetime.datetime.now()
mydate.strftime("%B")

回程:12月

有关 Python 文档网站的更多信息


[编辑:来自@GiriB的精彩评论] 您还可以使用 %b 返回月份名称的简短表示法。

mydate.strftime("%b")

对于上面的示例,它将返回Dec

日历 API

从中你可以看到calendar.month_name[3]会返回March,而0的数组索引是空字符串,所以也不需要担心零索引。

import datetime
monthinteger = 4
month = datetime.date(1900, monthinteger, 1).strftime('%B')
print month

四月

如果您只需要知道给定数字(1 - 12(的月份名称,则这并不那么有用,因为当前日期无关紧要。

calendar.month_name[i]

calendar.month_abbr[i]

在这里更有用。

下面是一个示例:

import calendar
for month_idx in range(1, 13):
    print (calendar.month_name[month_idx])
    print (calendar.month_abbr[month_idx])
    print ("")

示例输出:

January
Jan
February
Feb
March
Mar
...
import datetime
mydate = datetime.datetime.now()
mydate.strftime("%B") # 'December'
mydate.strftime("%b") # 'dec'

一次打印所有月份:

 import datetime
 monthint = list(range(1,13))
 for X in monthint:
     month = datetime.date(1900, X , 1).strftime('%B')
     print(month)

我会提供这个,以防(像我一样(你在数据帧中有一列月份数字:

df['monthName'] = df['monthNumer'].apply(lambda x: calendar.month_name[x])

一些好的答案已经使用了日历,但尚未提及设置区域设置的效果。

日历根据当前区域设置设置月份名称,例如法语:

import locale
import calendar
locale.setlocale(locale.LC_ALL, 'fr_FR')
assert calendar.month_name[1] == 'janvier'
assert calendar.month_abbr[1] == 'jan'

如果计划在代码中使用setlocale,请务必阅读文档中的提示和注意事项以及扩展编写器部分。此处显示的示例并不代表应如何使用它。特别是,从这两个部分:

在某些库例程中调用 setlocale(( 通常是一个坏主意,因为作为副作用,它会影响整个程序 [...]

扩展模块永远不应该调用 setlocale(( [...]

这就是

我要做的:

from datetime import *
months = ["Unknown",
          "January",
          "Febuary",
          "March",
          "April",
          "May",
          "June",
          "July",
          "August",
          "September",
          "October",
          "November",
          "December"]
now = (datetime.now())
year = (now.year)
month = (months[now.month])
print(month)

它输出:

>>> September

(这是我写这篇文章的真实日期(

datetime

基本日期和时间类型 — Python 文档

所有 strftime 格式代码的列表。月份的名称和格式等好东西留下零填充。阅读整页,了解"幼稚"论点的规则等内容。以下是简要列表:

%a  Sun, Mon, …, Sat 
%A  Sunday, Monday, …, Saturday 
%w  Weekday as number, where 0 is Sunday 
%d  Day of the month 01, 02, …, 31
%b  Jan, Feb, …, Dec
%B  January, February, …, December
%m  Month number as a zero-padded 01, 02, …, 12
%y  2 digit year zero-padded 00, 01, …, 99
%Y  4 digit Year 1970, 1988, 2001, 2013
%H  Hour (24-hour clock) zero-padded 00, 01, …, 23
%I  Hour (12-hour clock) zero-padded 01, 02, …, 12
%p  AM or PM.
%M  Minute zero-padded 00, 01, …, 59
%S  Second zero-padded 00, 01, …, 59
%f  Microsecond zero-padded 000000, 000001, …, 999999
%z  UTC offset in the form +HHMM or -HHMM   +0000, -0400, +1030
%Z  Time zone name  UTC, EST, CST
%j  Day of the year zero-padded 001, 002, …, 366
%U  Week number of the year zero padded, Days before the first Sunday are week 0
%W  Week number of the year (Monday as first day)
%c  Locale’s date and time representation. Tue Aug 16 21:30:00 1988
%x  Locale’s date representation. 08/16/1988 (en_US)
%X  Locale’s time representation. 21:30:00 
%%  literal '%' character.

'01' 到 'Jan'

from datetime import datetime
datetime.strptime('01', "%m").strftime("%b")    

对于月份数字的阿比塔雷范围

month_integer=range(0,100)
map(lambda x: calendar.month_name[x%12+start],month_integer)

将产生正确的列表。从月份整数列表中 1 月开始的位置调整start参数。

您可以使用我的手动功能,而不是导入或下载新的库:

将代码复制到新的.py文件并运行它

快速解释:

更改your_number并打印month_from_number,您将获得月份

    your_number = 10
    def num_to_month(*args, **kwargs):
        num = kwargs.get("num", None)
        if int(num) <= 12 and int(num) > 0:
            list_of_months = {'1': 'January', '2': 'February', '3': 'March',
                              '4': 'April', '5': 'May', '6': 'June', '7': 'July',
                              '8': 'August', '9': 'September', '10': 'October',
                              '11': 'November', '12': 'December'}
            return list_of_months[num]
        else:
            print('num_to_month function error: "num=' + str(num) + '"')
    month_from_num = num_to_month(num=your_number)
    print(month_from_num)

结果将是10月

此脚本用于演示如何获取数据框中月份变量/列的日历月缩写。请注意,假设月份列/变量的值都是数字,可能有一些缺失值。

# Import the calendar module
  import calendar
    
# Extract month as a number from the date column
  df['Month']=pd.DatetimeIndex(df['Date']).month
# Using list comprehension extract month abbreviations for each month number
 df['Month_abbr']=[calendar.month_abbr[int(i)] if pd.notna(i) else i for i in df['Month']]

如果你只有月份数字而不是日期时间实例,你可以构建一个小函数来映射带有标签的数字,如下所示:

def monthname(m):
    d={1:'En',2:'Fe',3:'Mr',4:'Ab',5:'My',6:'Jn',7:'Jl',8:'Ag',9:'Se',10:'Oc',11:'No',12:'Di'}
    return d[m]

来自一个关于生成月份名称列表的相关 SO 问题。

关于这个问题的许多选项,比如这个,都建议使用日历模块,尽管日期时间列表理解也可以这样做:

month_names = [dt.datetime.strptime(str(n), '%m').strftime('%B') for n in range(1, 13)]

如果您从查找大量整数的月份名称的角度来看待这个问题,则为预生成的列表编制索引可能会提高效率。

我创建了自己的函数,将数字转换为相应的月份。

def month_name (number):
    if number == 1:
        return "January"
    elif number == 2:
        return "February"
    elif number == 3:
        return "March"
    elif number == 4:
        return "April"
    elif number == 5:
        return "May"
    elif number == 6:
        return "June"
    elif number == 7:
        return "July"
    elif number == 8:
        return "August"
    elif number == 9:
        return "September"
    elif number == 10:
        return "October"
    elif number == 11:
        return "November"
    elif number == 12:
        return "December"

然后我可以调用该函数。例如:

print (month_name (12))

输出:

>>> December

相关内容

  • 没有找到相关文章

最新更新