自动批量裁剪+合成+整理正反向序列

说明

  • 自动识别,批量拼接文件夹中的16S rRNA 正反向序列。
  • 优化了前文中的方法,简化运行方式 点击查看。具体来说,拖动文件夹和文件 取代 输入路径
  • 在前面安装的包基础上,增加了 filesstrings

准备

  • 根据前文安装所需软件和包 点击查看
  • 额外安装 filesstrings
install.packages("filesstrings")
  • R 代码文件 点击下载
  • 文件夹包含成对的正反向序列。
    • 例如 D20-27F.seq 和 D20-1492R.seq,为一对。
    • 不严格要求为fasta格式,自动为缺少 >行 的序列文件添加这一行,名字使用文件名。
    • 根据 D20 识别,与27F和1492R无关,会自动调整正反位置。
    • 允许文件中有 D20 开头的 ab1 文件(峰图),会自动忽略。

运行

  1. 进入文件所在盘符。
  2. 输入 RScript, 空格。
  3. 拖入 R代码,回车。
  4. 再拖入包含序列的 文件夹,回车。
  5. 显示识别的路径,如果因为有中文出现乱码也会反应出来。
  6. CMD中显示合并的过程,联配的详情。
  7. 显示文件移动成功。


    merge2Seqs-howto.gif

结果

  • n 对序列生成 n 个文件夹,名字为 识别的名称_16SrRNA
  • 文件夹中包括所有以 识别的名称 开头的文件,包括原始序列,合成序列和合成报告。
  • 一个汇总所有合并序列信息:
    • 序号
    • 识别名字
    • 序列1长度
    • 序列1裁剪起点
    • 序列1裁剪终点
    • 序列2长度
    • 序列2裁剪起点
    • 序列2裁剪终点
    • 联配的长度(裁剪后)
    • 错配长度
    • 合成序列长度

注意

  • 根据第一次联配进行裁剪时,设置前后序列多裁剪了50个bp,减少错配的可能性。所以报告中显示100bp联配,实际上裁剪前有200bp的联配长度。
  • 代码 文件夹中还有用来测试的序列。
  • 可能不支持路径中包含中文。
  • 安装说明
  • 原理说明

转载于:https://www.cnblogs.com/Xeonilian/p/auto-batch-merge-16S-rRNA.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的示例代码,演示如何自动裁剪身份证正反面图片: ```csharp using System; using System.Drawing; public static void AutoCropIDCard(string imagePath, string croppedImagePath) { // 加载原始图片 Image originalImage = Image.FromFile(imagePath); // 计算身份证的宽度和高度 int idCardWidth = 850; int idCardHeight = 540; // 计算正面和反面图片的左上角坐标和宽度和高度 int frontX = 30; int frontY = 74; int frontWidth = 388; int frontHeight = 276; int backX = 435; int backY = 74; int backWidth = 388; int backHeight = 276; // 创建一个新的身份证大小的图片 Image croppedImage = new Bitmap(idCardWidth, idCardHeight); // 创建一个 Graphics 对象,用于在新图片上绘制原始图片的一部分 Graphics graphics = Graphics.FromImage(croppedImage); // 定义一个矩形,表示要截取的正面图片区域 Rectangle frontSourceRectangle = new Rectangle(frontX, frontY, frontWidth, frontHeight); // 定义一个矩形,表示要绘制的正面图片目标区域 Rectangle frontDestinationRectangle = new Rectangle(0, 0, frontWidth, frontHeight); // 绘制原始图片的正面部分到新图片上 graphics.DrawImage(originalImage, frontDestinationRectangle, frontSourceRectangle, GraphicsUnit.Pixel); // 定义一个矩形,表示要截取的反面图片区域 Rectangle backSourceRectangle = new Rectangle(backX, backY, backWidth, backHeight); // 定义一个矩形,表示要绘制的反面图片目标区域 Rectangle backDestinationRectangle = new Rectangle(frontWidth, 0, backWidth, backHeight); // 绘制原始图片的反面部分到新图片上 graphics.DrawImage(originalImage, backDestinationRectangle, backSourceRectangle, GraphicsUnit.Pixel); // 保存新图片 croppedImage.Save(croppedImagePath, ImageFormat.Jpeg); // 释放资源 graphics.Dispose(); croppedImage.Dispose(); originalImage.Dispose(); } ``` 在这个示例中,`imagePath` 参数是原始图片的路径,`croppedImagePath` 参数是要保存的新图片的路径。 这个方法会读取原始图片,根据身份证正反面图片的位置和大小,自动裁剪正反面图片,并将它们合并成一个新图片。最后,它会保存新图片到指定的路径。 您可以调用 `AutoCropIDCard` 方法来自动裁剪身份证图片。例如: ```csharp string imagePath = "path/to/image.jpg"; string croppedImagePath = "path/to/cropped/image.jpg"; AutoCropIDCard(imagePath, croppedImagePath); ``` 这个方法会读取原始图片,自动裁剪出身份证的正反面图片,并将它们合并成一个新图片,并将结果保存到新图片中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值