一、文件操作

1、判断一个目录是否存在,若不存在则创建

if not os.path.isdir(new_path):

os.makedirs(new_path)

2、新建一个文件

f=open("filename",'w')

f.close()

首先会判断这个文件是否存在,若不存在则新建,。也可以在open和close直接f.write()函数写文件。

3、比较两个文件是否相同

import filecmp

filecmp.cmp(r'文件1',r'文件2')

如果两个文件相同。会出输出true。否则输出false

二、系统级操作

1、获取当前运行脚本所在目录

import sys

sys.path[0]

2、获取当前工作路径

import os

os.getcwd()

3、 获取系统时间

import time   
    time.strftime('%Y-%m-%d',time.localtime(time.time()))
    输出格式类似2010-07-19

三、数据库操作

1、连接数据库

import MySQLdb

conn=MySQLdb.connect(host=host1,user=user1,passwd=pass1,port=port1,db=dbname)

cur=conn.cursor()

cur.close()

conn.close()

cursor是用来执行命令的方法,close断开连接,可在connect和close直接进行数据库的操作

2、数据库操作

conn.select_db('python')

count=cur.execute('select * from test')

result=cur.fetchone()

results=cur.fetchmany(5)

results=cur.fetchall()

conn.commit()

select_db()选择数据库

execute()执行单条sql语句,返回值为受影响的行数

fetchone() 返回一条结果行

fetchmany(size)接收size条返回结果行.如果size的值大于返回的结果行的数量,则会返回cursor.arraysize条数据.

fetchall() 返回所有结果值

3、数据库连接失败抛出异常

try:    conn=MySQLdb.connect(host=host1,user=user1,passwd=pass1,port=port1,db=dbname)

except MySQLdb.Error,e:

print "Mysql Error %d:%s" % (e.args[0],e.args[1])

四、其他功能型操作

1、将元组的值转化成字符串,并输出到文件,用到string下的join函数

例:  import string

seq=("apple","pair","orange")

f =open("/data/cheriegong/python/test.data",'w')

f.write(' '.join(seq))

f.close()

使用string.join(list) ,会报错:TypeError: sequence item 0: expected string, int found
        li = range(10)

print '\n'.join(li)

因为join函数处理的list,元素必须是string。它不进行任何的强制类型转换。对于其他类型需要强制转换为字符串。

下面为正确的调用:

li = range(10)

print '\n'.join(str(item) for item in li)

2、将string转换成list

可以用split函数,但是很麻烦。可以使用eval函数比较方便。例:eval('[1, 2, "a"]') 可以得到list [1, 2, "a"]。大部分用str()函数生成的string,都能用eval()还原成原来的对象。

3、获取命令行输入的参数

首先,必须 from optparse import OptionParser 类,创建一个 OptionParser 对象:

parser = OptionParser()

然后,使用 add_option 来定义命令行参数:

parser.add_option("-f", "--file", action="store", type="string", dest="filename")

-f是短参数;--file是长参数,可选;type数据类型,默认为string;dest用来保存参数值得变量,如果没有指定将用参数名来对option对象的值进行存取,这里即为file。action可用值有store,store_true,stote_false等。 store_true 和 store_false,用于处理带命令行参数后面不带值的情况。

例:-v,-q 等命令行参数:

parser.add_option("-v", action="store_true", dest="verbose")

parser.add_option("-q", action="store_false", dest="verbose")

这样的话,当解析到 ‘-v’,options.verbose 将被赋予 True 值,反之,解析到 ‘-q’,会被赋予 False 值。

最后,一旦你已经定义好了所有的命令行参数,调用 parse_args() 来解析程序的命令行:

(options, args) = parser.parse_args()

parse_args() 返回的两个值:options,它是一个对象(optpars.Values),保存所有命令行参数值。只要知道命令行参数名,如 file,就可以访问其对应的值:options.file 。

例:

parser.add_option("-f", "--file", action="store", type="string", dest="filename")

args = ["-f", "foo.txt"]

(options, args) = parser.parse_args(args)

print options.filename

最后将会打印出 “foo.txt”。

4、打印0~9 十个数字

print "\n".join(str(i) for i in range(10))

也可以用for循环实现

for i in range(10):

print i;

5、import指定目录下的模块

将文件所在路径加入sys.path,sys.path是一个list。import sys;

sys.path.append("/home/a/")

import b

为了避免由于之前存在一个同名模块导致加载失败,使用以下方法:

import sys;

if not "/home/a/" in sys.path:

sys.path.append("/home/a/")

if not 'b' in sys.modules:

b = __import__('b')

else:

eval('import b')

b = eval('reload(b)')

此外,在相同目录下.py文件,可以直接被import。

python常用代码积累的更多相关文章

  1. 【转载】GitHub 标星 1.2w+,超全 Python 常用代码合集,值得收藏!

    本文转自逆袭的二胖,作者二胖 今天给大家介绍一个由一个国外小哥用好几年时间维护的 Python 代码合集.简单来说就是,这个程序员小哥在几年前开始保存自己写过的 Python 代码,同时把一些自己比较 ...

  2. python 常用代码

    获取标签名 h1 class 是h1usersoup.find(name="h1", attrs={"class":"h1user"});获 ...

  3. JS date常用代码积累

    Date.prototype.Format = function(fmt) { var o = { "M+" : this.getMonth()+1, //月份 "d+& ...

  4. python常用代码片段

    目录 Python3常用 文件处理 json处理 log日志 argparse使用 INIparser Python3常用 文件处理 class BaseMethod: @staticmethod d ...

  5. python常用代码、问题汇总

    1.生成dataframe数据 5.读取带 ','分隔符的txt文件 4.DataFrame格式数据处理中报错 2.安装库时出现如下错误: 3.得到股票交易日数据 1.生成dataframe数据 im ...

  6. C# 个人常用代码积累

    /// <summary> /// TextBox限制只能输入十六进制,且只能输入6个 /// </summary> /// <param name="send ...

  7. python常用代码

    #coding=utf-8 import urllib import re def getHtml(url): page = urllib.urlopen(url) html = page.read( ...

  8. shell常用代码积累

    1.使用getopts从命令行接收参数 例: while getopts h:u:p: OPTION do case $OPTION in h) echo "主机地址:$OPTARG&quo ...

  9. Python 常用 代码片段

    文件名字中含有特殊字符转成空格,因为?‘’等作为文件名是非法的.以下正则表达式进行过滤转换 newname = re.sub("[\s+\.\!\/_,$%^*(+\"\')]+| ...

随机推荐

  1. Windows群集之NLB

    转http://www.aixchina.net/Article/31746 网络负载平衡群集(Network Load balancing) 在Internet快速发展的今天,为了满足企业的高速发展 ...

  2. -【线性基】【BZOJ 2460】【BZOJ 2115】【HDU 3949】

    [把三道我做过的线性基题目放在一起总结一下,代码都挺简单,主要就是贪心思想和异或的高斯消元] [然后把网上的讲解归纳一下] 1.线性基: 若干数的线性基是一组数a1,a2,a3...an,其中ax的最 ...

  3. 【UOJ 34】 多项式乘法 (FFT)

    [题意] 给你两个多项式,请输出乘起来后的多项式. 先打一个递归版本的模板... #include<cstdio> #include<iostream> #include< ...

  4. 最大流KK算法

    最大流KK算法 #include<iostream> #include<stdio.h> #include<string.h> #include<math.h ...

  5. 鬼谷子的钱袋 2006HNOI

    题目描述 Description 鬼谷子非常聪明,正因为这样,他非常繁忙,经常有各诸侯车的特派员前来向他咨询时政.有一天,他在咸阳游历的时候,朋友告诉他在咸阳最大的拍卖行(聚宝商行)将要举行一场拍卖会 ...

  6. 如何使用Eclipse插件—Easy Explorer

    Easy Explorer是一个Eclipse插件,主要用于快速浏览项目文件的目录,实用性比较强. 使用方法如下: 1.下载Easy Explorer,从此处下载EasyExplorer:http:/ ...

  7. centos安装openssl

    1.跳转到文件下载目录 cd install-file 2.下载openssl安装文件 wget http://www.openssl.org/source/openssl-1.0.2a.tar.gz ...

  8. JProfiler 5.1.4的使用方法

    1. JProfiler运行环境配置 安装目录结构如下,子目录中显示了支持的操作系统: 在服务器和客户端都要安装JProfiler,并且要安装License,在分析工具客户端中进行安装.Windows ...

  9. Spring Bean InitializingBean和DisposableBean实例

    在Spring中,InitializingBean和DisposableBean是两个标记接口,为Spring执行时bean的初始化和销毁某些行为时的有用方法. 对于Bean实现 Initializi ...

  10. C# httpwebrequest post 传输百分号‘%’

    转载:http://blog.csdn.net/qqstrive/article/details/8229601 通过webrequest的post传输数据的时候,如果url里面的参数带有‘%’,那么 ...