内置模块

今日内容回顾

  • os与sys模块
  • json模块

今日内容详情

os模块(重要)

os模块主要与代码运行所在的操作系统打交道

1.创建目录

import os
os.mkdir(r'd1')  # 相对路径 在执行文件所在的路径下创建目录 可以创建单级目录
# os.mkdir(r'd2\d22\d222') # 不可以创建多级目录
os.makedirs(r'd2\d22\d222')  # 可以创建多级目录
os.makedirs(r'd3')  # 也可以创建单级目录

2.删除目录

import os
os.rmdir(r'd1') # 可以删除单级目录
# os.rmdir(r'd2\d22\d222') # 不可以一次性删除多级目录
os.removedirs(r'd2\d22\d222') # 可以删除多级目录
os.removedirs(r'd2\d22\d222\d2222') # 只能删除空的多级目录
os.rmdir(r'd3') # 也只能删空的单级目录

3.列举指定路径下内容名称

import os
print(os.listdir())
print(os.listdir(r'D:\\'))

4.删除/重命名文件

import os
print(os.listdir())
print(os.listdir(r'D:\\'))

5.获取/切换当前工作目录

import os
print(os.getcwd())  # D:\pythonProject\day19
os.chdir('..')  # 切换到上一级目录
print(os.getcwd()) # D:\pythonProject

6.动态获取项目根目录(重要)

print(os.path.abspath(__file__))  # 获取执行文件的绝对路径
print(os.path.dirname(__file__))  # 获取执行文件所在的目录路径

7.判断路径是否存在(文件、目录)

import os
print(os.path.exists(r'a.py'))  # 判断文件路径是否存在 Ture
print(os.path.exists(r'D:\pythonProject\day19'))  # 判断目录是否存在 Ture
print(os.path.isfile(r'a.py'))  # 判断路径是否是文件 Ture
print(os.path.isfile(r'D:\pythonProject\day19'))  # 判断路径是否是文件 False
print(os.path.isdir(r'a.py'))  # 判断路径是不是目录 False
print(os.path.isdir(r'D:\pythonProject\day19'))  # 判断路径是不是目录 Ture

8.路径拼接(重要)

import os
s1 =  r'D:\pythonProject\day19'
s2 =  r'a.py'
错误做法 : print(f'{s1}\{s2}')
"""
涉及到路径拼接一定不要自己做 因为不同的操作系统路径分隔符不一样
"""
print(os.path.join(s1,s2))

9.获取文件大小(字节)

print(os.path.getsize(r'a.txt'))

sys模块

import sys
print(sys.path)  # 获取执行文件的sys.path
print(sys.getrecursionlimit())  # 获取python解释器默认最大递归深度
sys.setrecursionlimit(2000)  # 修改python解释器默认最大递归深度
print(sys.version) #3.8.8 (tags/v3.8.8:024d805, Feb 19 2021, 13:18:16) [MSC v.1928 64 bit (AMD64)]
print(sys.platform) # 平台信息 win32

res = sys.argv
if len(res) != 3:
    print('执行命令缺少了用户名或密码')
else:
    username = res[1]
    password = res[2]
    if username == 'jason' and password == '123':
        print('hello')
    else:
        print('sorry')

json模块

json模块也称为序列化模块 序列化可以打破语言限制实现不同编程语言之间数据交互

json格式数据的作用

json格式数据的形式
 字符串类型并且引号都是双引号
  
 json相关操作
  针对数据
   json.dumps()   序列化 (将python数据类型转换成json格式字符串)
   json.loads()    反序列化 (将json格式字符串转换成对应的数据类型)
dict1 = {'name':'jason','pwd':123,'age':18}
str_dcit1 = json.dumps(dict1)  # 序列化:将一个字典转换成一个字符串
print(type(str_dcit1),str_dcit1)  # <class 'str'> {"name": "jason", "pwd": 123, "age": 18}
# ps:json转换完的字符串类型的字典中的字符串是由""表示的

dict2 = json.loads(str_dcit1)  # 反序列化:将一个字符串格式的字典转换成一个字典
print(type(dict2), dict2)  # <class 'dict'> {'name': 'jason', 'pwd': 123, 'age': 18}
# ps:要用json的loads功能处理的字符串类型的字典中的字符串必须由""表示


list_dic = [1,['aa','bb','cc'],3,{'ke1':'vu1','ke2':'vu2'}]
str_dict = json.dumps(list_dic) # 可以处理嵌套数据类型
print(type(str_dict), str_dict)  # <class 'str'> [1, ["aa", "bb", "cc"], 3, {"ke1": "vu1", "ke2": "vu2"}]

list_dic2 = json.loads(str_dict)
print(type(list_dic2),list_dic2)  # <class 'list'> [1, ['aa', 'bb', 'cc'], 3, {'ke1': 'vu1', 'ke2': 'vu2'}
  
  针对文件
   json.dump()  将其它数据类型直接写入文件 (自动转json格式字符串)
  json.load()  将文件数据直接转成对应的数据类型 (自动反序列化)
  
  data = {'name':'jason', 'pwd':123, 'age':18}
with open(r'jason.json','w',encoding='utf8') as f:
    json.dump(data,f)


with open(r'jason.json','r',encoding='utf8') as f:
    loaded_json = json.load(f)
    print(type(loaded_json),loaded_json)  # <class 'dict'> {'name': 'jason', 'pwd': 123, 'age': 18}

json实战

# 用户登录注册功能
import os
import json
# 注册功能
# 1.获取执行文件所在的目录路径
base_dir = os.path.dirname(__file__)  # D:/pythonProject/day1
# 2.拼接出db目录的路径
db_dir = os.path.join(base_dir,'db')  # D:/pythonProject/day1\db
# 3. 创建db目录
if not os.path.isdir(db_dir):
    os.mkdir(db_dir)
# 4. 获取用户数据
username = input('username>>>>:').strip()
password = input('password>>>>:').strip()
# 5. 判断用户名是否已存在
# print(os.listdir(db_dir)) ['jason.json','kevin.json','tony.json'] # 方式1
user_file_path=os.path.join(db_dir,f'{username}.json')  # 方式2 
if not os.path.isfile(user_file_path):
    print('用户名不存在')
    exit(3)
# 6. 构建用户字典
user_dict = {'username': username,
             'password': password,
             'account': 15000, # 账户余额
             'shop_car': []
             }
# 7. 拼接存储用户数据的文件路径
user_file_path = os.path.join(db_dir,f'{username}.json')
# 8. 写入文件数据
with open(user_file_path,'w',encoding='utf8') as f:
    json.dump(user_dict,f)


# 登录功能
username = input('username>>>>>:').strip()
#1. 拼接上述用户名组成的文件路径
target_user_file_path = os.path.join(db_dir,f'{username}.json')
if not os.path.isfile(target_user_file_path):
    print('用户名不存在')
else:
    password = input('password>>>>').strip()
    # 2. 获取用户真实数据字典
    with open(target_user_file_path,'r',encoding='utf8') as f:
        real_user_dict = json.load(f)
    if password == real_user_dict.get('password'):
        print('登录成功')
    else:
        print('密码错误')
posted @   hugmi男孩  阅读(18)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
  1. 1 原来你也在这里 周笔畅
  2. 2 世间美好与你环环相扣 柏松
  3. 3 起风了 吴青峰
  4. 4 极恶都市 夏日入侵企划
原来你也在这里 - 周笔畅
00:00 / 00:00
An audio error has occurred, player will skip forward in 2 seconds.

作词 : 姚谦

作曲 : 中島みゆき

编曲 : Terence Teo

制作人 : 朱敬然

请允许我尘埃落定

请允许我尘埃落定

用沉默埋葬了过去

满身风雨我从海上来

才隐居在这沙漠里

该隐瞒的事总清晰

千言万语只能无语

爱是天时地利的迷信

喔 原来你也在这里

啊 那一个人

是不是只存在梦境里

为什么我用尽全身力气

却换来半生回忆

若不是你渴望眼睛

若不是我救赎心情

在千山万水人海相遇

喔 原来你也在这里

请允许我尘埃落定

请允许我尘埃落定

用沉默埋葬了过去

满身风雨我从海上来

才隐居在这沙漠里

该隐瞒的事总清晰

千言万语只能无语

爱是天时地利的迷信

喔 原来你也在这里

啊 那一个人

是不是只存在梦境里

为什么我用尽全身力气

却换来半生回忆

若不是你渴望眼睛

若不是我救赎心情

在千山万水人海相遇

喔 原来你也在这里

啊 那一个人

啊 那一个人

是不是只存在梦境里

为什么我用尽全身力气

却换来半生回忆

若不是你渴望眼睛

若不是我救赎心情

在千山万水人海相遇

喔 原来你也在这里

该隐瞒的事总清晰

千言万语只能无语

爱是天时地利的迷信

喔 原来你也在这里

OT: AISARERU HANA AISAREXIU HANA

OT: AISARERU HANA AISAREXIU HANA

(中文版:原来你也在这里)

OP: Yamaha Music Publishing Inc

SP:百代音乐版权代理(北京)有限公司

配唱制作人:翁乙仁

点击右上角即可分享
微信分享提示