python-删除文件的特定行

有一次需要删除一些html文件中的统计链接,
通过用遍历文本的每行,然后正则查找网址,使用下面的函数删除行。

删除文本文件的特定行

def removeLine(filename, lineno):
    fro = open(filename, "r",encoding='UTF-8')

    current_line = 0
    while current_line < lineno:
        fro.readline()
        current_line += 1

    seekpoint = fro.tell()
    frw = open(filename, "r+")
    frw.seek(seekpoint, 0)

    # read the line we want to discard
    fro.readline()  # 读入一行进内存 ,同时 文件指针下移实现删除

    # now move the rest of the lines in the file
    # one line back
    chars = fro.readline()
    while chars:
        frw.writelines(chars)
        chars = fro.readline()

    fro.close()
    frw.truncate()
    frw.close()

转载于:https://blog.51cto.com/13723657/2108743

### 回答1: 要删除csv文件中的特定,您可以使用Python的csv模块来读取和写入csv文件。以下是一些示例代码,可以帮助您删除csv文件中的特定: ```python import csv # 读取csv文件 with open('example.csv', 'r') as csvfile: reader = csv.reader(csvfile) # 创建一个新的csv文件来保存修改后的数据 with open('new_example.csv', 'w', newline='') as new_csvfile: writer = csv.writer(new_csvfile) # 遍历每一数据并删除指定 for row in reader: # 假设要删除第三数据 if reader.line_num == 3: continue # 跳过第三数据 else: writer.writerow(row) ``` 在上面的示例代码中,我们使用了两个csv文件:一个用于读取原始数据,另一个用于保存修改后的数据。我们遍历每一数据并检查是否为要删除。如果是,则跳过该数据。否则,将该数据写入新的csv文件。最终,您将获得一个不包含特定的csv文件。 ### 回答2: 在Python中,要删除CSV文件中的特定,可以使用`csv`模块进操作。 首先,你需要导入`csv`模块,并打开原始CSV文件和一个新的CSV文件,用于存储删除特定后的数据。 ```python import csv # 打开原始CSV文件和新的CSV文件 with open('原始文件.csv', 'r') as file, open('新文件.csv', 'w', newline='') as new_file: reader = csv.reader(file) writer = csv.writer(new_file) # 遍历原始文件的每一 for row in reader: # 根据特定的条件判断是否需要删除 if 条件成立: continue # 如果条件成立,则跳过该 # 将不需要删除写入新文件 writer.writerow(row) ``` 在上述代码中,你需要修改 '原始文件.csv' 和 '新文件.csv' 为实际文件名。然后,你需要根据特定的条件来判断是否需要删除。如果条件成立,则使用`continue`语句跳过该;否则,将写入新文件。 请根据你的具体需求修改上述代码,并使用合适的条件来删除特定。 ### 回答3: 要删除CSV文件中的特定,可以使用Python的csv模块来读取和写入CSV文件。下面是一个示例代码来实现这个功能: ```python import csv def delete_csv_row(filename, row_nums): # 读取CSV文件内容 with open(filename, 'r', newline='') as csvfile: reader = csv.reader(csvfile) rows = list(reader) # 删除特定 for row_num in sorted(row_nums, reverse=True): del rows[row_num] # 保存修改后的CSV文件 with open(filename, 'w', newline='') as csvfile: writer = csv.writer(csvfile) writer.writerows(rows) # 删除CSV文件的第2和第4 delete_csv_row('data.csv', [1, 3]) ``` 以上代码首先使用csv.reader()函数读取CSV文件的内容,并将其保存到一个二维列表rows中。然后,根据指定的号(row_nums),使用del语句删除这些。最后,使用csv.writer()函数将修改后的内容写回到CSV文件中。 需要注意的是,号是从0开始计数的。在上述示例中,删除的是第2和第4,对应的号是1和3。根据实际情况,可以修改row_nums来删除特定
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值