UDP Ping程序实现(头歌答案)

第一关

# UDPPingerServer.py 
from socket import * 

########## Begin ##########

# 创建UDP套接字
serverSocket = socket(AF_INET, SOCK_DGRAM)
# 绑定本机IP地址和端口号
serverSocket.bind(('', 12000))

########## End ##########
# 输出socket信息
print( serverSocket)

第二关

from socket import *

# 创建UDP套接字
serverSocket = socket(AF_INET, SOCK_DGRAM)
# 绑定本机IP地址和端口号
serverSocket.bind(('', 12000))

########## Begin ##########
# 接收客户端消息
message, address = serverSocket.recvfrom(1024)
# 将数据包消息转换为大写
message = message.upper()
#将消息传回给客户端
serverSocket.sendto(message, address)
########## End ##########

第三关

from socket import *
import random

# 创建UDP套接字
serverSocket = socket(AF_INET, SOCK_DGRAM)
# 绑定本机IP地址和端口号
serverSocket.bind(('', 12000))

num=0
while True:
        
    
    # 接收客户端消息
    message, address = serverSocket.recvfrom(1024)
    # 将数据包消息转换为大写
    message = message.upper()
        
    num=num+1
    if num>=8:
        break

    ########## Begin ##########
    # 对消息计数器模 3 为 1 的消息丢包
    if num % 3 == 1:
        continue
    ########## End ##########
    
    #将消息传回给客户端
    serverSocket.sendto(message, address)

第四关

from socket import *

########## Begin ##########
# 创建UDP套接字,使用IPv4协议
clientSocket = socket(AF_INET, SOCK_DGRAM) 
# 设置套接字超时值1秒
clientSocket.settimeout(1)
########## End ##########

print(clientSocket)
print(clientSocket.gettimeout())

第五关

from socket import *
import time

serverName = '127.0.0.1' # 服务器地址,本例中使用本机地址
serverPort = 12000 # 服务器指定的端口
clientSocket = socket(AF_INET, SOCK_DGRAM) # 创建UDP套接字,使用IPv4协议
clientSocket.settimeout(1) # 设置套接字超时值1秒

for i in range(0, 9):
    sendTime = time.time()
    message = ('Ping %d %s' % (i+1, sendTime)).encode()     # 生成数据报,编码为bytes以便发送

    try:
        ########## Begin ##########
        # 将信息发送到服务器
        clientSocket.sendto(message, (serverName, serverPort))
        # 从服务器接收信息,同时也能得到服务器地址(BUFSIZE为1024)
        modifiedMessage, serverAddress = clientSocket.recvfrom(1024) 
        ########## End ##########
        rtt = time.time() - sendTime # 计算往返时间

        print('Sequence %d: Reply from %s    RTT = %.3fs' % (i+1, serverName, rtt)) # 显示信息
    except Exception as e:
        print('Sequence %d: Request timed out.' % (i+1))

clientSocket.close() # 关闭套接字

这是`samtools mpileup`命令的一些输入和输出选项: 输入选项: - `-6, --illumina1.3+`: 指定质量采用Illumina-1.3+编码方式。 - `-A, --count-orphans`: 不丢弃异常的read pair。 - `-b, --bam-list FILE`: 指定一个包含多个BAM文件名的文件,每行一个文件名。 - `-B, --no-BAQ`: 禁用BAQ(基于位置的比对质量)。 - `-C, --adjust-MQ INT`: 调整mapping quality的,建议使用50,禁用则使用0。 - `-d, --max-depth INT`: 每个文件的最大深度,避免过多的内存使用,默认为8000。 - `-E, --redo-BAQ`: 在运行时重新计算BAQ,忽略现有的BQ。 - `-f, --fasta-ref FILE`: 指定一个已建立索引的参考序列文件。 - `-G, --exclude-RG FILE`: 排除在文件中列出的read group。 - `-l, --positions FILE`: 跳过未列出的位置(chr pos)或区域(BED)。 - `-q, --min-MQ INT`: 跳过比对质量小于INT的比对结果,默认为0。 - `-Q, --min-BQ INT`: 跳过碱基质量/BAQ小于INT的碱基,默认为13。 - `-r, --region REG`: 指定生成pileup的区域。 - `-R, --ignore-RG`: 忽略RG标签(一个BAM文件对应一个样本)。 - `--rf, --incl-flags STR|INT`: 必需的标志:跳过未设置掩码位的read,默认为空。 - `--ff, --excl-flags STR|INT`: 过滤标志:跳过设置了掩码位的read,默认为“UNMAP,SECONDARY,QCFAIL,DUP”。 - `-x, --ignore-overlaps`: 禁用read pair的重叠检测。 输出选项: - `-o, --output FILE`: 将输出写入到指定的文件中,默认为标准输出。 - `-O, --output-BP`: 输出read上的碱基位置。 - `-s, --output-MQ`: 输出mapping quality。 - `--output-QNAME`: 输出read的名称。 - `-a`: 输出所有位置(包括深度为0的位置)。 - `-a -a`(或`-aa`): 输出全部位置,包括未使用的参考序列。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值