Python Difflib 库将差异写入新文件

如何解决Python Difflib 库将差异写入新文件

我正在尝试运行一个 python 脚本来比较 2 个文件内容并将它们合并到一个文件中。

我有 2 个要比较的数据库模式。出于演示目的,我将它们命名为 file1file2

file1 看起来像这样。

USE [sql-database-one]
GO
/****** Object:  Table [dbo].[PeopleInfo]    Script Date: 23/06/2021 17:36:21 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[PeopleInfo](
    [PersonId] [int] NOT NULL,[FirstName] [text] NOT NULL,[LastName] [text] NOT NULL,[Age] [int] NULL
) ON [PRIMARY] TEXtimage_ON [PRIMARY]
GO
/****** Object:  Index [PK__PeopleIn__AA2FFBE5FDC5E42D]    Script Date: 23/06/2021 17:36:21 ******/
ALTER TABLE [dbo].[PeopleInfo] ADD PRIMARY KEY CLUSTERED 
(
    [PersonId] ASC
)WITH (PAD_INDEX = OFF,STATISTICS_norECOmpuTE = OFF,SORT_IN_TEMPDB = OFF,IGnorE_DUP_KEY = OFF,ONLINE = OFF,ALLOW_ROW_LOCKS = ON,ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
GO

file2 看起来像这样。

USE [sql-database-two]
GO
/****** Object:  Table [dbo].[PeopleInfo]    Script Date: 23/06/2021 17:54:57 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[PeopleInfo](
    [PersonId] [int] NOT NULL,[Age] [int] NULL,[SecondName] [text] NOT NULL
) ON [PRIMARY] TEXtimage_ON [PRIMARY]
GO
/****** Object:  Index [PK__PeopleIn__AA2FFBE59EF41C87]    Script Date: 23/06/2021 17:54:58 ******/
ALTER TABLE [dbo].[PeopleInfo] ADD PRIMARY KEY CLUSTERED 
(
    [PersonId] ASC
)WITH (PAD_INDEX = OFF,ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
GO

这只是一个用于测试目的的模型,两个文件间的唯一区别,除了数据库名称之外,就是表。 file2 有一个额外的列名 SecondName

使用 difflibs 我可以遍历行并打印出差异,我对结果很满意。

现在我想要实现的是将这些文件合并到 1 个文件中,所有差异都在正确的位置。

到目前为止我的代码是这样的。

file1 = open("backup.sql",'r')
file2 = open("backup2.sql",'r')

diff = difflib.context_diff(file1.readlines(),file2.readlines())
delta = ''.join(x[1:] for x in diff if x.startswith('! '))
# delta = ''.join(diff)
print(delta)


print('Diffs successfully written in result.sql')
with open('backup.sql','r+') as files1,open('backup2.sql') as files2:
    result = open('result.sql','w')
    f1 = [i.strip() for i in files1.readlines()]
    f2 = [j.strip() for j in files2.readlines()]
    f1 += [item for item in f2 if item not in f1]
    file1.seek(0)
    for line in f1:
        result.write(line + '\n')

我期望看到新文件,就在 Age 新列 SecondName 之后,但我得到的是:

USE [sql-database-one]
GO
/****** Object:  Table [dbo].[PeopleInfo]    Script Date: 23/06/2021 17:36:21 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[PeopleInfo](
[PersonId] [int] NOT NULL,[Age] [int] NULL
) ON [PRIMARY] TEXtimage_ON [PRIMARY]
GO
/****** Object:  Index [PK__PeopleIn__AA2FFBE5FDC5E42D]    Script Date: 23/06/2021 17:36:21 ******/
ALTER TABLE [dbo].[PeopleInfo] ADD PRIMARY KEY CLUSTERED
(
[PersonId] ASC
)WITH (PAD_INDEX = OFF,ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
GO
USE [sql-database-two]
/****** Object:  Table [dbo].[PeopleInfo]    Script Date: 23/06/2021 17:54:57 ******/
[Age] [int] NULL,[SecondName] [text] NOT NULL
/****** Object:  Index [PK__PeopleIn__AA2FFBE59EF41C87]    Script Date: 23/06/2021 17:54:58 ******/

所有差异都附加在文件底部。 任何人都可以帮助我或指导我如何在正确的行写差异的正确路径?

非常感谢

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

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?