python杂记二

1. 写文件可以直接使用print函数

file_name = open("file_name.txt","w")

print("file contain.",file = file_name)

file_name.close()

2. 判断一个文件有没有打开

可以判断文件变量有没有被定义,即有没有在locals()返回的集合中

try:
    file_name = open("file_name","r")
except IOError:
    print("File eror")
finally:
    if 'file_name' in locals():
        file_name.close()

3. 使用with语句就不再需要包含一个finally组来处理文件的关闭,python解释器会自动考虑这一点

打开多个文件时,中间用逗号分隔

try:
    with open("file_name1","w") as file_name1, open("file_name2","w") as file_name2:
        print("file1 contain.",file = file_name1)
        print("file2 contain.", file = file_name2)
except IOError:
    print("File eror")

4. print默认输出的位置是sys.stdout,即屏幕,其在sys模块中定义。file参数可以改变输出位置,比如输出到文件。

print函数的默认签名为 print(value, sep=' ', end='\n', file=sys.stdout)

5. python提供了一个标准库,名为pickle,可以保存和加载几乎任何python数据对象

需要导入所需要的模块,然后使用dump()保存数据,以后某个时间使用load()恢复数据。惟一的要求就是必须以二进制访问模式打开这些文件,如果出了问题,pickle模块会产生一个PickleError。

import pickle
try:
    with open("file_name","wb") as file_name:
        pickle.dump([1,2,3], file_name)
    with open("file_name2", "rb") as file_name2:
        temp_list = pickle.load(file_name2)
except IOError as err:
    print("File eror: " + str(err))
except pickle.PickleError as perr:
    print("Pickling error: " + str(perr))


6. 对于列表,sort()方法提供原地排序,sorted()方法提供复制排序,使用方法略有不同,如下

data.sort()      sorted(data)

两个方法默认升序,降序的话,要传入参数reverse=True

7. glob模块可以向操作系统查询一个文件名列表

import glob
data_files = glob.glob("data/*.txt")

8. python提供了自己的web服务器,这个web服务器包含在http.server库模块中。

构建一个web服务器要有这5行代码

# 导入HTTP服务器和CGI模块
from http.server import HTTPServer, CGIHTTPRequestHandler
# 指定一个接口
port = 8080
# 创建一个HTTP服务器
httpd = HTTPServer(('',port),CGIHTTPRequestHandler)
print("Starting simple_httpd on port: " + str(httpd.server_port))
httpd.serve_forever()


9. python的CGI模块可以用来访问表单数据

import cgi
# 获取所有表单数据并放在一个字典中
form_data = cgi.FieldStorage()


10. python的标准库提供了一个CGI跟踪模块:cgitb,启用这个模块时,会在web浏览器上显示详细的错误消息。这些消息可以帮助你找出CGI中哪里出了问题,改正错误而且CGI正常工作后中,再关掉CGI跟踪

import cgitb
cgitb.enable()

11. python3 预装了SQLite3,要使用SQLite,只需要导入sqlite3库,燕使用Python的标准化数据库API来编程

# 导入sqlite3库
import sqlite3
# 建立与数据库的连接
connection = sqlite3.connect('test.sqlite')
# 创建游标
cursor = connection.cursor()
# 建表
cursor.execute("""CREATE TABLE students(
                    id INTEGER PRIMARY KEY AUTOINCREMENT UNIQUE NOT NULL,
                    name TEXT NOT NULL,
                    dob DATE NOT NULL)""")
cursor.execute("""CREATE TABLE score(
                    student_id INTEGER NOT NULL,
                    value TEXT NOT NULL,
                    FOREIGN KEY (student_id) REFERENCES students)""")
connection.commit()
cursor.execute("INSERT INTO students (name,dob) VALUES (?,?)",(name,dob))
connection.commit()
cursor.execute("SELECT id from students WHERE name=? AND dob=?",(name,dob))
cursor.execute("SELECT value FROM score WHERE student_id=?",(student_id,))
# 游标方法返回的都是数据行列表
# 返回下一个数据行
cursor.fetchone()
# 返回多个数据行
cursor.fetchmany()
# 返回所有数据
cursor.fetchall()
connection.close()

12. os库可以查询系统环境变量

import os
os.environ['path']

13. python在函数中对直接使用全局变量时,会查找同名的局部变量,找不到就会报UnboundLocalError异常。要在函数里修改一个全局变量时,要在函数里global + 变量名进行声明。

sayhi = 'hello'
def what_to_say():
    global sayhi
    print(sayhi)
    sayhi = 'bey-bey'
    print(sayhi)

猜你喜欢

转载自www.cnblogs.com/zhaoshizi/p/9975550.html