from datetime import * import time print(date.min,date.max,date.fromordinal(32)) d = date(2019,10,1) print(d.year,d.month, d.day) d.replace(month= 12) print(d.toordinal(),d.weekday(),d.ctime(),d.strftime("%Y/%m/%d(%a)"))
时间: 2024-04-01 22:36:43 浏览: 8
执行结果是:
输出datetime模块中date类的最小值和最大值,以及将序数转换为日期的结果。
输出d的年、月、日。
调用replace()方法,但由于date对象是不可变的,replace()方法不会修改原对象,所以d的值仍然是(2019,10,1)。
输出d的序数、星期和格式化日期字符串。
最终输出的结果如下:
0001-01-01 9999-12-31 0001-02-01
2019 10 1
737333 1 Tue Oct 1 00:00:00 2019 2019/10/01(Tue)
相关问题
filepath = r"C:\Users\a0005921\Desktop\各分段比重.xlsx" wb = openpyxl.load_workbook(filepath,data_only=True) # TEST_DATA = [{ 'label': '项目调研', 'start':'2019-02-01 12:00:00', 'end': '2019-03-15 18:00:00'}] Stname = wb["统计"] TEST_DATA = [] for rowdata in Stname.iter_rows(min_row=2,max_row=Stname.max_row,min_col=0,max_col=Stname.max_column): # print(rowdata[6].value) if rowdata[6].value == None: continue else: start_date = datetime.strftime(rowdata[5].value,"%Y-%m-%d") end_date = datetime.strftime(rowdata[6].value,"%Y-%m-%d") actual_s_date = datetime.strftime(rowdata[9].value,"%Y-%m-%d") actual_e_date = datetime.strftime(rowdata[10].value,"%Y-%m-%d") dict = {'分段':rowdata[1].value, 'start':start_date, 'end':end_date, 'actual_s':actual_s_date, 'actual_e':actual_e_date,} TEST_DATA.append(dict)优化这段代码
可以对代码进行如下的优化:
1. 使用 pathlib 模块来更好地处理文件路径,避免使用转义字符;
2. 删除无用的注释和空行,使代码更加简洁;
3. 将日期转换代码的部分提取出来,避免重复代码;
4. 将字典 key 的命名规范化。
改写后的代码如下:
```python
from pathlib import Path
import openpyxl
from datetime import datetime
file_path = Path(r"C:\Users\a0005921\Desktop\各分段比重.xlsx")
workbook = openpyxl.load_workbook(file_path, data_only=True)
sheet = workbook["统计"]
TEST_DATA = []
for row in sheet.iter_rows(min_row=2, max_row=sheet.max_row, min_col=0, max_col=sheet.max_column):
if row[6].value is None:
continue
else:
start_date = datetime.strftime(row[5].value, "%Y-%m-%d")
end_date = datetime.strftime(row[6].value, "%Y-%m-%d")
actual_s_date = datetime.strftime(row[9].value, "%Y-%m-%d")
actual_e_date = datetime.strftime(row[10].value, "%Y-%m-%d")
data_dict = {
'segment': row[1].value,
'start_date': start_date,
'end_date': end_date,
'actual_start_date': actual_s_date,
'actual_end_date': actual_e_date
}
TEST_DATA.append(data_dict)
```
# 统计性描述 print(df1.describe()) # 将日期转换为数字 df1['date'] = df1['date'].apply(lambda x: date2num(pd.to_datetime(x))) # 获取日期数据的最小值和最大值 date_min = mdates.date2num(df1['date'].min()) date_max = mdates.date2num(df1['date'].max()) # 绘制K线图 fig, ax = plt.subplots() ax.plot(df1['date'], df1['close'], label='Close') ax.plot(df1['date'], df1['open'], label='Open') ax.plot(df1['date'], df1['high'], label='High') ax.plot(df1['date'], df1['low'], label='Low') ax.legend() ax.set_xlabel('Date') ax.set_ylabel('Price') ax.set_title('坤彩科技') # 设置横轴的显示格式和间隔 #from matplotlib.dates import MonthLocator, DateFormatter #ax.xaxis.set_major_locator(MonthLocator()) # 设置横坐标主刻度为月份 #ax.xaxis.set_major_formatter(DateFormatter('%Y-%m')) # 设置刻度标签的格式为"年-月",可以根据需要进行修改 ax.xaxis.set_major_locator(YearLocator(base=1)) # 设置横坐标主刻度为年份 ax.xaxis.set_major_formatter(DateFormatter('%Y')) # 设置刻度标签的格式为"年" ax.xaxis.set_minor_locator(MonthLocator(bymonth=(3, 6, 9, 12))) # 设置横坐标次刻度为季度 ax.tick_params(axis='x', which='minor', labelsize=8, labelrotation=45) # 设置次刻度标签的大小和旋转角度 font = fm.FontProperties(size=10, style='italic') # 设置斜体字体属性 plt.xticks(fontproperties=font) # 设置刻度标签为斜体 plt.savefig('a1.jpg') # 保存图表 plt.show() # 显示图表 写一个循环,相同上述绘图,从1到14
可以将上述绘图的代码放在一个函数中,然后使用循环调用这个函数实现从1到14的绘图。
示例代码如下:
```python
import pandas as pd
import matplotlib.pyplot as plt
import matplotlib.dates as mdates
from matplotlib.dates import YearLocator, DateFormatter, MonthLocator
import matplotlib.font_manager as fm
# 定义绘制K线图的函数
def plot_k_line(df):
# 将日期转换为数字
df['date'] = df['date'].apply(lambda x: mdates.date2num(pd.to_datetime(x)))
# 获取日期数据的最小值和最大值
date_min = mdates.date2num(df['date'].min())
date_max = mdates.date2num(df['date'].max())
# 绘制K线图
fig, ax = plt.subplots()
ax.plot(df['date'], df['close'], label='Close')
ax.plot(df['date'], df['open'], label='Open')
ax.plot(df['date'], df['high'], label='High')
ax.plot(df['date'], df['low'], label='Low')
ax.legend()
ax.set_xlabel('Date')
ax.set_ylabel('Price')
ax.set_title('坤彩科技')
# 设置横轴的显示格式和间隔
ax.xaxis.set_major_locator(YearLocator(base=1)) # 设置横坐标主刻度为年份
ax.xaxis.set_major_formatter(DateFormatter('%Y')) # 设置刻度标签的格式为"年"
ax.xaxis.set_minor_locator(MonthLocator(bymonth=(3, 6, 9, 12))) # 设置横坐标次刻度为季度
ax.tick_params(axis='x', which='minor', labelsize=8, labelrotation=45) # 设置次刻度标签的大小和旋转角度
font = fm.FontProperties(size=10, style='italic') # 设置斜体字体属性
plt.xticks(fontproperties=font) # 设置刻度标签为斜体
plt.show() # 显示图表
# 循环调用绘图函数
for i in range(1, 15):
filename = f'data{i}.csv' # 根据数据文件名字生成文件路径
df = pd.read_csv(filename) # 读取数据
plot_k_line(df) # 绘制K线图
plt.savefig(f'a{i}.jpg') # 保存图表
```
注意:上述代码中需要将数据文件命名为`data1.csv`、`data2.csv`、`data3.csv`...`data14.csv`,并且放在当前目录下。