Python
MTV与MVC+url控制器 MVC框架: · M:model.py 就是和数据库打交道用的,创建表等操作 · V:View 视图(视图函数:逻辑处理响应函数,html文件) · C:controller 控制器(请求文件路径与响应函数的映射表:urls文件里面的内容,url(路径)分发与视图函数的逻辑处理) Web服务器开发领域里著名的MVC模式,所谓MVC就是把Web应用分为模型(M),控制器(C)和视图(V)三层,他们之间以一种插件式的、松耦合的方式连接在一起,模型负责业务对象与数据库的映射(ORM),视图负责与用户的交互(页面),控制器接受用户的输入调用模型和视图完成用户的请求,其示意图如下所示: MTV框架: · M:model.py 就是和数据库打交道用的,创建表等操作(和MVC一样) · T:templates 存放HTML文件的 · V:View 视图函数(逻辑处理) 对比: MTV比MVC少一个url分发的部分 Django 的引入: Django是基于MTV模式的框架,需要配合url控制器(路径分发)使用! Django的MTV模式本质上和MVC是一样的,也是为了各组件间保持松耦合关系,只是定义上有些许不同,Django的MTV分别是值: · M 代表模型(Model): 负责业务对象和数据库的关系映射(ORM)。 · T 代表模板 (Template):负责如何把页面展示给用户(html)。 · V 代表视图(View): 负责业务逻辑,并在适当时候调用Model和Template。 除了以上三层之外,还需要一个URL分发器,它的作用是将一个个URL的页面请求分发给不同的View处理,View再调用相应的Model和Template,MTV的响应模式如下所示: 一般是用户通过浏览器向我们的服务器发起一个请求(request),这个请求回去访问视图函数,(如果不涉及到数据调用,那么这个时候视图函数返回一个模板也就是一个网页给用户),视图函数调用模型,模型去数据库查找数据,然后逐级返回,视图函数把返回的数据填充到模板中空格中,最后返回网页给用户。
阅读全文

使用pandas简单写Excel

1. 环境准备 我使用的是在Win10下,需要安装几个依赖包: pip install xlrd pip install pandas pip install openpyxl 如果需要用到数据库读写模块,则需要安装Mysql-Python模块: (https://download.lfd.uci.edu/pythonlibs/t7epjj8p/MySQL_python-1.2.5-cp27-none-win32.whl "Win32位下载") 2.上代码 代码完成的主要功能是从数据库读取BUG列表数据,同时写入数据库 import pandas as pd title = list() resolveBy = list() resolution = list() openedDate = list() assignedDate = list() resolvedDate = list() closeDate = list() ## 从数据库中读取数据分别对列表赋值 data = pd.read_excel('1.xlsx', sheet_name='Sheet1') print '标题||解决人||处理结果||创建日期||分配日期||解决日期||关闭日期' data = title data = resolveBy data = resolution data = openedDate data = assignedDate data = resolvedDate data = closeDate data.to_excel('1.xlsx', sheet_name='Sheet1', index=False, header=True)
阅读全文

Python的datetime模块分析(转)

datetime模块用于是date和time模块的合集,datetime有两个常量,MAXYEAR和MINYEAR,分别是9999和1.datetime模块定义了5个类,分别是1.datetime.date:表示日期的类2.datetime.datetime:表示日期时间的类3.datetime.time:表示时间的类4.datetime.timedelta:表示时间间隔,即两个时间点的间隔5.datetime.tzinfo:时区的相关信息一、首先看一下datetime.date类:date类有三个参数,datetime.date(year,month,day),返回year-month-day方法:1.datetime.date.ctime(),返回格式如 Sun Apr 16 00:00:00 20172.datetime.date.fromtimestamp(timestamp),根据给定的时间戮,返回一个date对象;datetime.date.today()作用相同3.datetime.date.isocalendar():返回格式如(year,month,day)的元组,(2017, 15, 6)4.datetime.date.isoformat():返回格式如YYYY-MM-DD5.datetime.date.isoweekday():返回给定日期的星期(0-6),星期一=0,星期日=66.datetime.date.replace(year,month,day):替换给定日期,但不改变原日期7.datetime.date.strftime(format):把日期时间按照给定的format进行格式化。8.datetime.date.timetuple():返回日期对应的time.struct_time对象  time.struct_time(tm_year=2017, tm_mon=4, tm_mday=15, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=5, tm_yday=105, tm_isdst=-1)9.datetime.date.weekday():返回日期的星期python中时间日期格式化符号:%y 两位数的年份表示(00-99)%Y 四位数的年份表示(000-9999)%m 月份(01-12)%d 月内中的一天(0-31)%H 24小时制小时数(0-23)%I 12小时制小时数(01-12)%M 分钟数(00=59)%S 秒(00-59)%a 本地简化星期名称%A 本地完整星期名称%b 本地简化的月份名称%B 本地完整的月份名称%c 本地相应的日期表示和时间表示%j 年内的一天(001-366)%p 本地A.M.或P.M.的等价符%U 一年中的星期数(00-53)星期天为星期的开始%w 星期(0-6),星期天为星期的开始%W 一年中的星期数(00-53)星期一为星期的开始%x 本地相应的日期表示%X 本地相应的时间表示%Z 当前时区的名称%% %号本身二、看一下datetime的time类time类有5个参数,datetime.time(hour,minute,second,microsecond,tzoninfo),返回08:29:301.datetime.time.replace()2.datetime.time.strftime(format):按照format格式返回时间3.datetime.time.tzname():返回时区名字4.datetime.time.utcoffset():返回时区的时间偏移量三、datetime的datetime类datetime类有很多参数,datetime(year, month, day),返回年月日,时分秒datetime.datetime.ctime()datetime.datetime.now().date():返回当前日期时间的日期部分datetime.datetime.now().time():返回当前日期时间的时间部分datetime.datetime.fromtimestamp()datetime.datetime.now():返回当前系统时间datetime.datetime.replace()datetime.datetime.strftime():由日期格式转化为字符串格式datetime.datetime.now().strftime('%b-%d-%Y %H:%M:%S')  'Apr-16-2017 21:01:35'datetime.datetime.strptime():由字符串格式转化为日期格式datetime.datetime.strptime('Apr-16-2017 21:01:35', '%b-%d-%Y %H:%M:%S')2017-04-16 21:01:35 四、datetime的timedelta类datetime.datetime.timedelta用于计算两个日期之间的差值,例如:>>> a=datetime.datetime.now()>>> b=datetime.datetime.now()>>> adatetime.datetime(2017, 4, 16, 21, 21, 20, 871000)>>> bdatetime.datetime(2017, 4, 16, 21, 21, 29, 603000)>>> b-adatetime.timedelta(0, 8, 732000)>>> (b-a).seconds8或者time1 = datetime.datetime(2016, 10, 20)time2 = datetime.datetime(2015, 11, 2)"""计算天数差值"""print(time1-time2).days"""计算两个日期之间相隔的秒数"""print (time1-time2).total_seconds()原文链接:https://www.cnblogs.com/cindy-cindy/p/6720196.html
阅读全文