python读取txt文本文件-批量更改mysql数据库中一批用户的用户名的python脚本保存及转存关于OSI的七层模型和TCP/IP四层模型

本文主要是介绍python读取txt文本文件-批量更改mysql数据库中一批用户的用户名的python脚本保存及转存关于OSI的七层模型和TCP/IP四层模型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、python读取txt文本文件-批量更改mysql数据库中一批用户的用户名的python脚本保存

    做一个简单的事:使用python读取一个txt文件,里面存储着N行用户id,需要一行行读取后再读取另一个存储用户昵称的txt文件,判断昵称是否有重复,如果没有重复就将数据库中的当前uid用户的昵称进行更换 publish:April 9, 2019 -Tuesday。

        使用python按行读取文本内容以及全部一次读取文本的实现方法如下:

#按行读取方法1:
f = open("data.txt","r")
#读取第一行内容,包括换行符,可使用line[:-1]去掉换行符号,也可以使用.strip()来实现。
line = f.readline()
line = line[:-1]
#line = line.strip()
while line:line = f.readline()line = line[:-1]
f.close()#按行读取方法2:
data = []
for line in open("data.txt","r"):data.append(line)#一次性全部读取方法1
f = open("data.txt","r") 
data = f.readlines()  #直接将文件中按行读到list里
f.close()#一次性全部读取方法2
import numpy as np
data = np.loadtxt("data.txt")  #将文件中数据加载到data数组里#为了方便,避免忘记close掉这个文件对象,可以用下面这种方式替代上面的open方法
with open('data.txt',"r") as f: str = f.read()

实现的python脚本保存,以备后用:

#!/usr/bin/python
# -*- coding: utf8 -*-
import MySQLdb
import MySQLdb.cursors
import sys 
import timereload(sys)
sys.setdefaultencoding( "utf-8" )#连接MYSQL
def db_connection():conn = MySQLdb.connect(host='192.168.1.11',db='database',user='user',passwd='passwd',port=3306,charset='utf8',cursorclass=MySQLdb.cursors.DictCursor)conn.autocommit(1)return conn#判断用户名是否存在 
def checkUser(username):db_conn = db_connection()cursor=db_conn.cursor()cursor.execute("select uid from user_list where username='" + username + "'")return cursor.fetchone()#变更主表和分表用户数据
def updateUser(uid, username):db_conn = db_connection()cursor=db_conn.cursor()print "update user_list set username='" + username + "',password='e10adbe56e057f20f883ec3949ba59ab' where uid = " + uidcursor.execute("update user_list set username='" + username + "',password='e10adbe56e057f20f883ec3949ba59ab' where uid = " + uid)userid_fix = int(uid[-2:])print "update user_"+ str(userid_fix) +" set username='" + username + "',password='e10adbe56e057f20f883ec3949ba59ab' where user_id = " + uidprint '               -----|-------|----|-----|'cursor.execute("update user_"+ str(userid_fix) +" set username='" + username + "',password='e10adbe56e057f20f883ec3949ba59ab' where user_id = " + uid)#读取用户username数据
unames = open("user_data.txt")#取得用户ID列表
user_fp = open("id_data.txt")
line = user_fp.readline().strip()
count = 0
while line:uname = unames.readline().strip()if not uname:print 'user name is not enough'    exit()data= checkUser(uname)while data:uname = unames.readline().strip()if not uname:print 'user name is not enough'    exit()data= checkUser(uname)#print line + ' --> ' + unameupdateUser(line, uname)count += 1;#getUser(line);#if(count>0):#    user_fp.close()#    exit()line = user_fp.readline().strip()user_fp.close()
print '--------------success--------------'
exit()

二、转载存储: 关于OSI的七层模型和TCP/IP四层模型

注:本文应该是转载的某篇文章内容,迁移时未发现有备注转载地址,如作者有意,请联系删除。

1. OSI参考模型

    物理层 --- 数据表示。物理层规定了激活、维持、关闭通信端点之间的机械特性、电气特性、 功能特性以及过程特性。该层为上层协议提供了一个传输数据的物理媒体。EIA/TIA、RS-232、EIA/TIA RS-449、V.35、RJ-45等。
    数据链路层 --- 主机间通信。数据链路层在不可靠的物理介质上提供可靠的传输。SDLC、HDLC、PPP、STP、帧中继等。
    网络层 --- 端到端的连接。网络层负责对子网间的数据包进行路由选择。此外,网络层还可以实现拥塞控制、网际互连等功能。IP、IPX、RIP、OSPF等。
    传输层 --- 寻址和最短路径。传输层是第一个端到端,即主机到主机的层次。传输层负责将上层数据分段并提供端到端的、可靠的或不可靠的传输。TCP、UDP、SPX等。
    会话层 --- 介质访问。会话层管理主机之间的会话进程,即负责建立、管理、终止进程之间的会话。会话层还利用在数据中插入校验点来实现数据的同步。NetBIOS、ZIP(AppleTalk区域信息协议)等。
    表示层 --- 二进制传输。表示层对上层数据或信息进行变换以保证一个主机应用层信息可以被另一个主机的应用程序理解。表示层的数据转换包括数据的加密、压缩、格式转换等。ASCII、ASN.1、JPEG、MPEG等。
    应用层 --- 应用层为操作系统或网络应用程序提供访问网络服务的接口。Telnet、FTP、 HTTP、SNMP等。

关于OSI的七层模型和TCP/IP四层模型[转载]

        在这个OSI七层模型中,每一层都为其上一层提供服务、并为其上一层提供一个访问接口或界面。不同主机之间的相同层次称为对等层。如主机A中的表示层和主机B中的表示层互为对等层、主机A中的会话层和主机B中的会话层互为对等层等。对等层之间互相通信需要遵守一定的规则,如通信的内容、通信的方式,我们将其称为协议(Protocol)。OSI参考模型的提出是为了解决不同厂商、不同结构的网络产品之间互连时遇到的不兼容性问题。但是该模型的复杂性阻碍了其在计算机网络领域的实际应用。 与此对照,后面我们将要学习的TCP/IP参考模型,获得了非常广泛的应用。实际上,也是目前因特网范围内运行的唯一一种协议。

2. TCP/IP参考模型

     主机到网络层 --- 实际上TCP/IP参考模型没有真正描述这一层的实现,只是要求能够提供给其上层-网络互连层一个访问接口,以便在其上传递IP分组。由于这一层次未被定义,所以其具体的实现方法将随着网络类型的不同而不同。
     网络互连层   --- 网络互连层是整个TCP/IP协议栈的核心。它的功能是把分组发往目标网络或主机。同时,为了尽快地发送分组,可能需要沿不同的路径同时进行分组传递。因此,分组到达的顺序和发送的顺序可能不同,这就需要上层必须对分组进行排序。网络互连层定义了分组格式和协议,即IP协议(Internet Protocol)。
     传输层       --- 在TCP/IP模型中,传输层的功能是使源端主机和目标端主机上的对等实体可以进行会话。在传输层定义了两种服务质量不同的协议。即:传输控制协议TCP(transmission control protocol)和用户数据报协议UDP(user datagram protocol)。 
                    TCP协议是一个面向连接的、可靠的协议。它将一台主机发出的字节流无  
                    差错地发往互联网上的其他主机。在发送端,它负责把上层传送下来的字 
                    节流分成报文 段并传递给下层。在接收端,它负责把收到的报文进行重组后
                    递交给上层。TCP协议还要处理端到端的流量控制,以避免缓慢接收的接收 
                    方没有足够的缓冲区接收 发送方发送的大量数据。
                    UDP协议是一个不可靠的、无连接协议,主要适用于不需要对报文进行排序
                    和流量控制的场合。
    应用层    --- TCP/IP模型将OSI参考模型中的会话层和表示层的功能合并到应用层实现。

关于OSI的七层模型和TCP/IP四层模型[转载]

    ISO制定的OSI参考模型的过于庞大、复杂招致了许多批评。与此对照,由技术人员自己开发的TCP/IP协议栈获得了更为广泛的应用。上图是TCP/IP参考模型和OSI参考模型的对比示意图。下图是一些应用调用的传输层示例等。

关于OSI的七层模型和TCP/IP四层模型[转载]

这篇关于python读取txt文本文件-批量更改mysql数据库中一批用户的用户名的python脚本保存及转存关于OSI的七层模型和TCP/IP四层模型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127212

相关文章

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

Python实现终端清屏的几种方式详解

《Python实现终端清屏的几种方式详解》在使用Python进行终端交互式编程时,我们经常需要清空当前终端屏幕的内容,本文为大家整理了几种常见的实现方法,有需要的小伙伴可以参考下... 目录方法一:使用 `os` 模块调用系统命令方法二:使用 `subprocess` 模块执行命令方法三:打印多个换行符模拟

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成

从入门到进阶讲解Python自动化Playwright实战指南

《从入门到进阶讲解Python自动化Playwright实战指南》Playwright是针对Python语言的纯自动化工具,它可以通过单个API自动执行Chromium,Firefox和WebKit... 目录Playwright 简介核心优势安装步骤观点与案例结合Playwright 核心功能从零开始学习

Python 字典 (Dictionary)使用详解

《Python字典(Dictionary)使用详解》字典是python中最重要,最常用的数据结构之一,它提供了高效的键值对存储和查找能力,:本文主要介绍Python字典(Dictionary)... 目录字典1.基本特性2.创建字典3.访问元素4.修改字典5.删除元素6.字典遍历7.字典的高级特性默认字典

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java