python两个文件内容异或,python 异或两个文件-程序员宅基地

技术标签: python两个文件内容异或  

问题描述:python以16进制读取文本,就是获取以下图片红框中的DF,F8,DF这些16进制,然后做一些处理,再写到文件中。

5f6c192ec86823b4e407ecc7f0729476.png

1个字节 == 8Bit == 两个hex(1~F)

文件读取可以按行readline。。

f = open('1.txt','rb')

while True:

t = f.readline()

if not t :

break

f.close() 但这么做,只能获取一个str对象

str转成hexs[]:

hexs = []

for ss in s:

tmp = (hex(ord(ss)).replace('0x',''))

if len(tmp) == 2:#DF之类的

hexs.append(tmp)

else:#0D之类的,默认写成D

hexs.append('0'+tmp) 但这么做,获取的hexs,也是type(str)对象,hex()本来返回的是就是一个str对象

hexs[]转成真正的16进制数据:

其实到这里一想,python内部的数字表示一定都是2进制啊,我用16进制最终写入文件的是二进制,用10进制最终写入文件的也依旧是二进制。那么,思路是直接把hexs转成10进制,反正计算机内部一定把它当成2进制了。

arr = ['0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f']

arr2 = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]

def tran(r):#把0~F转成数字

for i in range(len(arr)):

if r == arr[i]:

return arr2[i]

res = []

for i in range(len(hexs)):

a = tran(hexs[i][0])*16+tran(hexs[i][1])

res.append(a) 但这么做,写入文件是不成功的,比如说我要往文件写16进制FD,上面代码将它转成253,但是这么写入文件,不是我们期盼的。我们要在最上面的图片的红框中写入了FD,而不是在黑框中写入了253。

10进制转成2进制,文件open的时候,带上'b'参数

Ps:别忘了import strcut

ff = open('out.txt','wb')

for i in res:

B = struct.pack('B',i)

ff.write(B)

ff.close()

如此一来就写入文件成功,思路到这里就完成了。

对两个文件的xor处理

# -*- coding: cp936 -*-

import binascii

import struct

#每个字节转成hex,0x顺便去掉,对于不足两位的补0

def str2hex(str):

hexs = []

for s in str:

tmp = (hex(ord(s)).replace('0x',''))

if len(tmp) == 2:

hexs.append(tmp)

else:

hexs.append('0'+tmp)

return hexs

arr = ['0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f']

arr2 = [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]

def tran(r):

for i in range(len(arr)):

if r == arr[i]:

return arr2[i]

f = open('1.txt','rb')

f2 = open('2.jpg','rb')

hexs = []

hexs2 = []

while True:

t = f.readline()

t2 = f2.readline()

if not t or not t2:

break

hexs.extend(str2hex(t))

hexs2.extend(str2hex(t2))

f.close()

f2.close()

ff = open('out.txt','wb')

for i in range(min(len(hexs),len(hexs2))):

a = tran(hexs[i][0])*16+tran(hexs[i][1])

b = tran(hexs2[i][0])*16+tran(hexs2[i][1])

B = struct.pack('B',a^b)

ff.write(B)

ff.close()

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_39680380/article/details/116178549

智能推荐

python宝典 宋强 pdf_Python宝典/宝典丛书:杨佩璐//宋强 : 电子电脑 :计算机技术 :程序与语言 ...-程序员宅基地

文章浏览阅读279次。导语《Python宝典》由杨佩璐、宋强等编著,本书内容共分三篇26章,分别为入门篇、高级篇和案例篇,针对Python的常用扩展模块给出了详细的语法介绍,并且给出了典型案例,通过对本书的学习,读者能够很快地使用Python进行编程开发。本书以PVthon 3.x为基础进行讲解,并在与Python 2.x有区别的地方加上了相关介绍,使Pvthon 2.x和Pvthon 3.x的读者都能使用本书。内容提..._python宝典杨佩璐

js对象遍历输出的时候真的是按照顺序输出吗?_map循环遍历对象数据是顺序的吗-程序员宅基地

文章浏览阅读1.3w次。js对象遍历输出的时候真的是按照顺序输出吗?  下边就来实践一下:var obj={'3':'ccc',name:'abc',age:23,school:'sdfds',class:'dfd',hobby:'dsfd'};Object.keys(obj)输出:["3", "name", "age", "school", "class", "hobby"];换一下对象顺序,var obj=_map循环遍历对象数据是顺序的吗

HDU--4305(生成树计数)-程序员宅基地

文章浏览阅读176次。2015-09-0722:23:26【传送门】题意:平面上300个点,如果两点之间距离<=R,且两点形成的线段上没有另外的点,那么两点之间有一条无向边。问生成树的方案数。思路:暴力n^2建图,关于判断两点形成线段上是否有其他点,比如判断 k 点知否在 i ,j 之间,首先看斜率是否相等,不能直接求斜率,而应该转化为乘式;再判断 dis(i,k)+dis(k,j)是否等..._hdu4305

阿里云OSS请求文件跨域问题Access-Control-Allow-Origin_oss预签名url access-control-allow-origin-程序员宅基地

文章浏览阅读2.2k次。跨域问题网上很多解决方案提示到这里配置但是不生效,一定要勾选Vary:Origin这个选项,请求的时候浏览器记得请求在控制台要清理缓存。_oss预签名url access-control-allow-origin

OpenCV - C++ - cv::setWindowProperty-程序员宅基地

文章浏览阅读4k次,点赞2次,收藏2次。OpenCV - C++ - cv::setWindowPropertyHigh-level GUI#include <opencv2/highgui.hpp>1. setWindowProperty()void cv::setWindowProperty(const String &winname, int prop_id, double prop_value) - C++None = cv.setWindowProperty(winname, prop_id, prop__setwindowproperty

Qt Creator 4.13中的CMake项目配置_qt cmake configuration-程序员宅基地

文章浏览阅读5.1k次,点赞3次,收藏4次。在Qt Creator中配置中型到大型CMake项目可能是一个挑战。这是因为您需要给CMake传递正确配置项目的选项太多了。让我们以Qt Creator的CMake为例。不同于qmake构建,CMake构建可配置你想要构建的插件。_qt cmake configuration

随便推点

AMOS分析技术:二阶验证性因子分析-程序员宅基地

文章浏览阅读4.8w次,点赞5次,收藏90次。基础准备草堂君在前面介绍了验证性因子分析的内容,包括验证性因子分析与探索性因子分析的区别联系,斜交验证性因子分析和正交验证性因子分析,可以点击下方文章链接回顾:AMOS分析技术:验证性因子分析介绍;信度与效度指标详解AMOS分析技术:斜交验证性因子分析;介绍如何整理出能够放入论文的模型信效度结果AMOS分析技术:正交验证性因子分析;模型拟合质量好,模型就一定好吗?今天草堂君要介绍的是二阶验证性因子_二阶验证性因子分析

读jQuery之二十(Deferred对象)-程序员宅基地

文章浏览阅读55次。为什么80%的码农都做不了架构师?>>> ...

C++代码实现Top-K问题最优解决办法_c++用优先队列解决topk-程序员宅基地

文章浏览阅读1.6k次。Top-K问题Top-K问题1、问题描述2、解法思想和实现Top-K问题1、问题描述Top-K问题是一个十分经典的问题,一般有以下两种方式来描述问题:在10亿的数字里,找出其中最大的100个数;或者在一个包含n个整数的数组中,找出最大的100个数。前边两种问题描述稍有区别,但都是说的Top-K问题,前一种描述方式是说这里也许没有足够的空间存储大量的数字或其他东西,我们最好可以在一边输入数据,一边求出结果,而不需要存储数据;后一种说法则表示可以存储数据,这种情况下,最简单直观的想法就是对数组进行排序,_c++用优先队列解决topk

怎么用matlab剔除数据的异常值(3σ准则)_3sigma原则matlab-程序员宅基地

文章浏览阅读5.2w次,点赞27次,收藏379次。参考:https://blog.csdn.net/weixin_30633405/article/details/951770093σ准则又称为拉依达准则,它是先假设一组检测数据只含有随机误差,对其进行计算处理得到标准偏差,按一定概率确定一个区间,认为凡超过这个区间的误差,就不属于随机误差而是粗大误差,含有该误差的数据应予以剔除。且3σ适用于有较多组数据的时候。这种判别处理原理及方法仅局限于对正态或近似正态分布的样本数据处理,它是以测量次数充分大为前提的,当测量次数较少的情形用准则剔除粗大误_3sigma原则matlab

导入PYQT5不能使用的坑_pdroid3已经导入pyqt5怎么不管用-程序员宅基地

文章浏览阅读5.1k次,点赞4次,收藏17次。如图:import进来之后里面的类全都不能用是因为这个引用路径下面有中文。改成英文的就不报错了,如果还是报错,那就新建一个项目命名成英文_pdroid3已经导入pyqt5怎么不管用

手推线性模型及最小二乘法(房价预测实例)_基于最小二乘法的房价预测实验报告-程序员宅基地

文章浏览阅读1.4k次,点赞4次,收藏24次。手推线性模型及最小二乘法(房价预测实例)线性模型及最小二乘法推导房价预测实例Reference线性模型及最小二乘法推导房价预测实例生成数据#生成数据import numpy as np#生成随机数np.random.seed(1234)x = np.random.rand(500,3)#构建映射关系,模拟真实的数据待预测值,映射关系为y = 4.2 + 5.7*x1 + 1..._基于最小二乘法的房价预测实验报告

推荐文章

热门文章

相关标签