配置文件的选择_Cisco备份配置文件

配置文件的选择_Cisco备份配置文件不同模式打开文件的完全列表:模式描述r以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。rb以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。r+

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

 

不同模式打开文件的完全列表:

模式 描述
r 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
rb 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。
r+ 打开一个文件用于读写。文件指针将会放在文件的开头。
rb+ 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
w 打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
wb 以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
w+ 打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
wb+ 以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
a 打开一个文件用于追加。如果该文件不存在则创建新文件进行写入。
ab 以二进制格式打开一个文件用于追加。如果该文件不存在则创建新文件进行写入。
a+ 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
ab+ 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。

 

有文件config.txt如下,要读取文件中的值

m_url=https://onetouch-partner.aba.com/login.htm?
b_url=https://onetouch-partner.aba.com/ptnBasedata/crm/
c_url=https://onetouch-partner.aba.com/ptnBasedata/crm/customerList.htm
titls=[公司名称,创建时间,访问时间,生成时间,签约情况,跟进情况,公司地址,联系人姓名,电话,企业邮箱,联系人邮箱]
filename=客户信息
word=IDL2020888**

file 对象方法
f.read([size]):size 未指定则返回整个文件,如果文件大小 >2 倍内存则有问题,f.read()将整个文件内容作为一个字符串,读到文件尾时返回””(空字串)。
f.readline():返回一行。
f.readlines([size]) :返回包含size行的列表, size 未指定则返回全部行。
for line in f: print line :通过迭代器访问。

f.write(“hello\n”):如果要写入字符串以外的数据,先将他转换为字符串。
f.close() 关闭文件

 

绝对路径就是文件的真正存在的路径,是指从硬盘的根目录(盘符)开始,进行一级级目录指向文件。
相对路径就是以当前文件为基准进行一级级目录指向被引用的资源文件。

../ 表示当前文件所在的目录的上一级目录
./ 表示当前文件所在的目录(可以省略)
/ 表示当前站点的根目录(域名映射的硬盘目录)
py文件与要读取文件在统一目录下可直接读取,不用家路径

 

python中转义用\,路径用/,因此windows路径可以是/(与linux一致)也可以用\\,Unix和Web用正斜杠/,Windows用反斜杠,但是现在Windows
python读文件需要输入的目录参数,以下path都是正确的:
path1 = r”C:\Windows\temp\readme.txt” # “\”为字符串中的特殊字符,加上r后变为原始字符串,则不会对字符串中的”\t”、”\r” 进行字符串转义
path2 = “c:\\windows\\temp\\readme.txt” # 用一个”\”取消第二个”\”的特殊转义作用,即为”\\”
path3 = “c:/windows/temp/readme.txt” # 用正斜杠做目录分隔符也可以转到对应目录,并且在python中path3的方式也省去了反斜杠\转义的烦恼

 

f = open(file) # 打开文件
content = f.read()
print(content)
f.close() # 关闭文件

#read
with  open('sample1.txt') as f:
    content = f.read()
    print(content)

#readline读取该文件:
with  open('a.txt') as f:
    print(f.readline())
    print(f.readline(5))

#readlines方法没有参数:
with  open('a.txt') as f:
    print(f.readlines())


f = open('sample3.txt','w') # 打开文件
content = f.write('hello,my friends!\nthis is python big data analysis')
f.close() # 关闭文件


with  open('sample3.txt','w') as f:
    f.write('hello,my friends!\nthis is python big data analysis')

 

 

def read_myconfig():
    ss=[]
    f = open("config.txt",'r',encoding='utf-8')    #返回一个文件对象
    # print(f)
    for line in f:
        ss.append(line.split('=')[1].strip("\n"))
    f.close()
    print(ss)
read_myconfig()

def read_myconfig():
    ss=[]
    f = open("config.txt",'r+',encoding='utf-8')    #返回一个文件对象
    line = f.read()    #调用文件的 readline()方法
    f.close()
    # print(line.split('\n'))
    for i in (line.split('\n')):
        ss.append(i.split('=')[1])#以每行的换行划分,将每行作为列表的一个元素。
    print(ss)
read_myconfig()

def read_myconfig():
    ss=[]
    f = open("config.txt",'r+',encoding='utf-8')    #返回一个文件对象
    line = f.readline()    #调用文件的 readline()方法
    # print(line)
    while line:
        ss.append(line.split()[0].split('=')[1])#先过滤掉行末的换行
        line = f.readline()
    f.close()
    print(ss)
read_myconfig()

def read_myconfig():
    ss=[]
    f = open("config.txt",'r',encoding='utf-8')    #返回一个文件对象
    line = f.readlines()    #调用文件的 readline()方法
    f.close()
    # print(line)
    for i in line:
        ss.append(i.split('=')[1].strip("\n"))
    print(ss)
read_myconfig()


def read_myconfig():
    f = open("config.txt",'r',encoding='utf-8')    #返回一个文件对象
    line = f.readlines()    #调用文件的 readline()方法
    f.close()
    # print(line)
    ss=[i.split('=')[1].strip("\n") for i in line]
    print(ss)
read_myconfig()

  

 结果如下:

['https://onetouch-partner.aba.com/login.htm?', 'https://onetouch-partner.aba.com/ptnBasedata/crm/',
'https://onetouch-partner.aba.com/ptnBasedata/crm/customerList.htm',
'[公司名称,创建时间,访问时间,生成时间,签约情况,跟进情况,公司地址,联系人姓名,电话,企业邮箱,联系人邮箱]', '客户信息', 'IDL2020888**']

在python中存在继承了 回车符\r 和 换行符\n 两种标记

aa=’https://\rone touch-pa rtner.aba.com/login.htm?\n’
print(aa.replace(‘\n’, ”).replace(‘\r’, ”) ) 去掉 aa字符内所有的 回车符和换行符
print(aa.replace(‘ ‘, ”) ) 去掉 aa字符内所有的 空格
print(aa.strip()) 只能够去除aa字符串首尾的空格,不能够去除中间的空格

 

 

常用的配置文件后缀是.ini、.conf、.py,当然还有使用.json、.txt的,推荐使用常用的.ini、.py

用Python变量作为配置文件格式

把配置直接用变量的形式写到一个模块中,在需要读取配置的地方直接import模块就能得到配置变量:

配置文件示例:

# config.py

listen_port = 4444

use_epoll = True

在读取配置的地方:

import config

port_num = config.listen_port

if config.use_epoll:

    …

优点

直接用python变量作为配置文件格式的优点是显然的:

l  不用任何解释器来解释配置文件。Python解释器本身就可以。

l  使用自然、方便,直接可用,和其他变量的使用没有任何区别。

l  学习成本低,不需要学习其他配置文件的格式和语法。

缺点

方便之处在于不用parser,缺点也在于不用parser。通常情况,配置文件是人负责写,程序负责读。但如果配置文件既要让人写也要让代码写。比如程序的配置可以直接改配置文件,同时也提供了一套界面让用户在界面上修改配置。在界面上修改的配置,最终也是反映到配置文件中,这就要求代码修改配置文件了。此时会有少许不便。

 

.ini.tx作为配置文件格式

.ini、.txt配置文件使用方法是一致的,只是一个后缀的区别,这里以ini配置文件来介绍,这类配置文件我们使用内置configparser库来使用,它可以实现配置文件的写入、更新、删除、读取等操作非常方便,建议使用这种方式。新建一个config.ini的配置文件内容如下:

[mysql]
name = admin
host = 255.255.255.0
proxy = 6037
password = 123456
pool = true
time = 3
#其中[]中的是section节点,该节点下的等式是键值对

常用方法如下:

# -*- coding: utf-8 -*-

import configparser

config = configparser.ConfigParser()
config.read("Config.ini", encoding="utf-8")

config.sections()  # 获取section节点
config.options('mysql')  # 获取指定section 的options即该节点的所有键
config.get("mysql", "name")  # 获取指定section下的options

config.items("mysql")  # 获取section的所用配置信息

config.set("mysql", "name", "root")  # 修改值

config.has_section("mysql")  # 是否存在该section
config.has_option("mysql", "password")  # 是否存在该option

config.add_section("redis")  # 添加section节点
config.set("redis", "name", "redis_admin")  # 设置指定section 的options

config.remove_section("redis")  # 整个section下的所有内容都将删除

config.remove_option("mysql", 'time')  # 删除section下的指定options

config.write(open("Config", "w"))  # 保存config

  

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/167849.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 移掉 K 位数字

    移掉 K 位数字

    2020年11月19日
    207
  • drawstring 文本居中_c#-Graphics.DrawString()的中心文本输出

    drawstring 文本居中_c#-Graphics.DrawString()的中心文本输出c Graphics DrawString 的中心文本输出我正在使用 NETCF WindowsMobil Graphics 类和 DrawString 方法将单个字符呈现到屏幕 问题是我似乎无法使其正确居中 无论我为字符串渲染的位置的 Y 坐标设置什么 它总是比该值低 并且文本大小越大 Y 偏移量就越大 例如 在文本大小 12 处 偏移量约为 4 但在 32 处 偏移量约为 10 我希望角色垂直占据绘制的

    2025年11月2日
    3
  • 信号带宽与信道带宽「建议收藏」

    信号带宽与信道带宽「建议收藏」
    信号带宽是信号频谱的宽度,也就是信号的最高频率分量与最低频率分量之差,譬如,一个由数个正弦波叠加成的方波信号,其最低频率分量是其基频,假定为f=2kHz,其最高频率分量是其7次谐波频率,即7f=7×2=14kHz,因此该信号带宽为7f-f=14-2=12kHz。
       信道带宽则限定了允许通过该信道的信号下限频率和上限频率,也就是限定了一个频率通带。比如一个信道允许的通带为1.5kHz至15kHz,其带宽为13.5kHz,上面这个方波信号的所有频率成分当然能从该信道通过,如果

    2022年10月11日
    2
  • goland 2021.2.3 服务器激活(在线激活)

    goland 2021.2.3 服务器激活(在线激活),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月14日
    365
  • 华硕路由器、LEDE、梅林,阿里DDNS教程

    华硕路由器、LEDE、梅林,阿里DDNS教程转自我的博客:sleele.com/2019/04/17/…教程华硕路由器官方固件,梅林,LEDE大体一致,下面我以华硕路由器官改固件为例展开教程首先安装阿里DDNS插件,在阿里注册一个域名,买最便宜的即可,购买域名后进入控制台设置域名解析按照图标顺序操作之后后让你输入手机验证码,之后就可以得到AccessKeyID、AccessKey…

    2022年6月11日
    83
  • java程序员必须知道的mysql优化的知识

    java程序员必须知道的mysql优化的知识

    2021年8月3日
    137

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号