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()

 输出结果:

例二:

#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()

 输出结果:

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()

输出结果:

常用的库:

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()查看数据类型就可以看出区别):

元组:

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()查看数据类型就可以看出区别):

字典:

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()查看数据类型): 

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')))

  输出结果:

2、os库实战:

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

1)、命令行处理:

import json

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

  输出结果:

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__))))

  输出结果:

(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()针对具体的文件

输出的结果:

3、hashlib库实战

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

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

import hashlib


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

输出结果:

 

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

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中常用的导包的方法和常用的库的更多相关文章

  1. Python中异步协程的使用方法介绍

    1. 前言 在执行一些 IO 密集型任务的时候,程序常常会因为等待 IO 而阻塞.比如在网络爬虫中,如果我们使用 requests 库来进行请求的话,如果网站响应速度过慢,程序一直在等待网站响应,最后 ...

  2. 举例详解Python中的split()函数的使用方法

    这篇文章主要介绍了举例详解Python中的split()函数的使用方法,split()函数的使用是Python学习当中的基础知识,通常用于将字符串切片并转换为列表,需要的朋友可以参考下   函数:sp ...

  3. python中执行shell的两种方法总结

    这篇文章主要介绍了python中执行shell的两种方法,有两种方法可以在Python中执行SHELL程序,方法一是使用Python的commands包,方法二则是使用subprocess包,这两个包 ...

  4. Python 中的时间处理包datetime和arrow

    Python 中的时间处理包datetime和arrow 在获取贝壳分的时候用到了时间处理函数,想要获取上个月时间包括年.月.日等 # 方法一: today = datetime.date.today ...

  5. 【转】Android中引入第三方Jar包的方法(java.lang.NoClassDefFoundError解决办法)

    原文网址:http://www.blogjava.net/anchor110/articles/355699.html 1.在工程下新建lib文件夹,将需要的第三方包拷贝进来.2.将引用的第三方包,添 ...

  6. Python中os和shutil模块实用方法集…

    Python中os和shutil模块实用方法集锦 类型:转载 时间:2014-05-13 这篇文章主要介绍了Python中os和shutil模块实用方法集锦,需要的朋友可以参考下 复制代码代码如下: ...

  7. Python中os和shutil模块实用方法集锦

    Python中os和shutil模块实用方法集锦 类型:转载 时间:2014-05-13 这篇文章主要介绍了Python中os和shutil模块实用方法集锦,需要的朋友可以参考下 复制代码代码如下: ...

  8. Python中的str与unicode处理方法

    Python中的str与unicode处理方法 2015/03/25 · 基础知识 · 3 评论· Python 分享到:42 原文出处: liuaiqi627 的博客    python2.x中处理 ...

  9. Python中常见字符串去除空格的方法总结

    Python中常见字符串去除空格的方法总结 1:strip()方法,去除字符串开头或者结尾的空格>>> a = " a b c ">>> a.s ...

随机推荐

  1. 在python3.6环境下使用cxfreeze打包程序

    在python3.6环境下使用cxfreeze打包程序 环境:python3.6 打包程序:aliens_invasion 原本想使用pyintaller 进行打包,使用pip的安装过程也没有问题,打 ...

  2. Android系统编程入门系列之应用内数据保存数据库

    上篇文章已经介绍了如何使用SharedPreferences存储键值对形式的轻量级数据,对于那些相同结构的多组数据,类似于存储Java中定义的类的多个对象属性值,如果按照键值对的形式一条条读写,需要分 ...

  3. [第七篇]——Docker Hello World之Spring Cloud直播商城 b2b2c电子商务技术总结

    Docker Hello World Docker 允许你在容器内运行应用程序, 使用  docker run 命令来在容器内运行一个应用程序. 输出Hello world xxx@xxx:~$ do ...

  4. 【转】Linux 查看端口占用情况

    Linux 查看端口占用情况可以使用 lsof 和 netstat 命令. lsof lsof(list open files)是一个列出当前系统打开文件的工具. lsof 查看端口占用语法格式: l ...

  5. java版gRPC实战之五:双向流

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  6. 记一次PHP的Invalid binding type问题

    首先说明下环境问题,新旧服务器的迁移.代码在老服务器运行没有任何问题.环境都是PHP7.3,结果新的服务器上流量导过来以后,就报出了如下问题: FastCGI sent in stderr: &quo ...

  7. 微信小程序生成小程序某一个页面的小程序码

    1 登录微信小程序后台,mp.weixin.qq.com 2 点击右上角工具->生成小程序码 3 填写小程序名称或appid 4 关键一步,下面页面填写用户微信号后,打开小程序到某一个页面,点击 ...

  8. springboot多数据源配合docker部署mysql主从实现读写分离

    本篇主要有两部分: 1.使用docker部署mysql主从 实现主从复制 2.springboot项目多数据源配置,实现读写分离 一.使用docker部署mysql主从 实现主从复制 此次使用的是wi ...

  9. Python - 生成requirement.text 文件

    前言 该篇操作笔记摘自小菠萝 Python项目中,一般都会有一个 requirements.txt 文件 这个文件主要是用于记录当前项目下的所有依赖包及其精确的版本号,以方便在一个新环境下更快的进行部 ...

  10. Docker系列(20)- 数据卷容器

    数据卷容器 什么是数据卷容器? 容器和容器之间实现数据共享 一个容器先于宿主机创建挂载方式,宿主机就会有改卷的目录 第二个容器使用命令--volumes-from 第一个容器,共享使用了第一个容器与宿 ...