python中常用的导包的方法和常用的库

时间:2023-03-08 17:57:21
python中常用的导包的方法和常用的库

python中常用的导包的方法

              导入包和包名的方法:1、import package.module

              2、from package.module import  *

例一:
#second.py

def register():
print('this is a register page')

  

#first.py页面调用registe()方法时

#1、
import zero.second zero.second.register() #2、
from zero.second import * register()

 输出结果:

python中常用的导包的方法和常用的库

例二:

#func.py

def logout():
print('this is a logout function') class Logout(object):
def profile(self): #实例化
print('this is a profile method')

  

#second.py

def register():
print('this is a register page')

常用的导包方式:1、from package.modlue import *
                   2、from package.package.modlue import *

from zero.first import login
from zero.second import register
from zero.one.func import logout,Logout

#导入包后,可直接调用下面的方法,来获取这些方法里面的内容
login()
register()
logout()
obj=Logout()
obj.profile()

 输出结果:

python中常用的导包的方法和常用的库

sys库实战

PS:有时候导入包以后,还是会提示报错,提示找不到路径,用一下的方法解决:

import sys
import os '''提示first的模块不存在,找不到错误的解决方案'''
base_dir=os.path.dirname(os.path.dirname(__file__)) #先定义base_dir,输出D:\code\testDev\zero路径 sys.path.append(os.path.join(base_dir,'zero')) for item in sys.path:
print(item) from first import login
login()

输出结果:

python中常用的导包的方法和常用的库

常用的库:

1、json库的应用

在python中,序列化:把python的数据类型(字典、元组、列表)转为str的数据类型;

         反序列化:把str的数据类型转为python对象的过程。

序列化和反序列化在列表、元组和字典中的应用:

列表:

import json

lists=[1,2,3,4]

#序列化
list_str=json.dumps(lists) ##先对lists进行序列化list_str
print('内容:',list_str,'序列化后的列表类型:',type(list_str))
#反序列化
str_list=json.loads(list_str) ##再对list_str进行反序列化str_list
print('内容:',str_list,'反序列化后的列表类型:',type(str_list))

  输出结果(输出的内容可能看不出来效果,通过type()查看数据类型就可以看出区别):

python中常用的导包的方法和常用的库

元组:

import json

tuple1=(1,2,3,4) #序列化
tuple_str=json.dumps(tuple1) #格式化的时候
print('内容:',tuple_str,'序列化后的列表类型:',type(tuple_str))
# #反序列化
str_tuple=json.loads(tuple_str)
print('内容:',str_tuple,'序列化后的列表类型:',type(str_tuple))

  输出结果(输出的内容可能看不出来效果,通过type()查看数据类型就可以看出区别):

python中常用的导包的方法和常用的库

字典:

import json

dict1={'name':'lyl','age':18}

# #序列化
dict_str=json.dumps(dict1)
print('内容:',dict_str,'序列化后的列表类型:',type(dict_str))
# #反序列化
str_dict=json.loads(dict_str)
print('内容:',str_dict,'序列化后的列表类型:',type(str_dict))

 输出结果(双引号和单引号并不能说明数据类型的转变,通过type()查看数据类型): 

python中常用的导包的方法和常用的库

dump():把目标数据写到文件里面
load():从文件里面读取数据
import json

dict1={'name':'lyl','age':18,'address':'xian'}

#把dict1的内容用w模式写到log.md里面,
json.dump(dict1,open('log.md','w'))
#读取log.md里面的内容
print(json.load(open('log.md','r')))

  输出结果:

python中常用的导包的方法和常用的库

python中常用的导包的方法和常用的库

2、os库实战:

 os是针对:1、命令行处理
      2、路径处理

1)、命令行处理:

import json

print('获取当前的路径:',os.getcwd())
#查看tomcat端口是不是被占用,当然首先要启动端口,不启动端口不用端口就不存在占用的问题。
print(os.system('netstat -ano | findstr "8080"')) #netstat -ano | findstr "8080"这个命令可以直接再cmd中打开

  输出结果:

python中常用的导包的方法和常用的库

2)、路径处理

(1)获取路径

import os

'''获取路径 os.path.dirname()'''
#获取D:\code\testDev\zero路径
print(os.path.dirname(__file__))
#获取D:\code\testDev路径
print(os.path.dirname(os.path.dirname(__file__)))
#获取D:\code路径
print(os.path.dirname(os.path.dirname(os.path.dirname(__file__))))

  输出结果:

python中常用的导包的方法和常用的库

(2)路径的拼接(login.json在别的文件夹下面):

import os

'''路径拼接 os.path.join()'''
base_dir=os.path.dirname(os.path.dirname(__file__))
print(os.path.join(base_dir,'data','login.json'))

print('判断是否是文件:',os.path.isfile('D:/code/mysql/utils/')) #os.path.isfile()针对文件路径
print('判断是否是目录:',os.path.exists('D:/code/mysql/utils/yamlUtils.py')) #os.path.exists()针对具体的文件

输出的结果:

python中常用的导包的方法和常用的库

3、hashlib库实战

  hashlib是设计安全散列和消息摘要,提供多个不同的加密算的接口,如:SHA1、SHA224、SHA256、SHA384、SHA512、MD5等。

  针对---字符串的基本用法:

import hashlib


m=hashlib.md5()
m.update('heiheihei'.encode('utf-8'))
print(m.hexdigest())#返回十六进制数字字符串

输出结果:

 python中常用的导包的方法和常用的库

  针对---字典加密的用法:

from urllib import parse
import hashlib
import time def sign():
dict1={'name':'lyl','age':18,'sex':'girl','address':'xian','time':time.time()} #'time':time.time()不加时间每次的加密那个数字都一样,加了时间就每次加密不一样。
data=sorted(dict1.items(),key=lambda item:item[0])
data1=parse.urlencode(data)
#加密
m=hashlib.md5() #创建hash对象,md5(message-Digest Algorithm 5):消息摘要算法,得出一个128位的密文
m.update(data1.encode('utf-8')) #更新data1对象以字符串参数的形式
print(m.hexdigest()) #返回十六进制数字字符串 sign()

 输出结果:

python中常用的导包的方法和常用的库