ChIP-seq实践(H3K27Ac,enhancer的筛选和enhancer相关基因的GO分析)

在实践之前,我先查找了一下有关组蛋白修饰的知识点:
(参考文章:https://www.jianshu.com/p/8aca72809c5c

组蛋白修饰能预测染色质的类型(异染色质或常染色质)、区分基因组功能元件(启动子、增强子、基因主体)以及检测决定这些元件处于活性状态或是抑制状态。例如H3K4me2和H3K4me3修饰大多数富集在转录起始位点附近的启动子上激活基因表达,而H3K27me2和H3K27me3与基因抑制相关。因此可通过CHIP-seq分析组蛋白修饰的分布寻找基因的启动子区和增强子区域及其是激活或抑制基因表达。

H3K4me1可作为增强子的标志,H3K4me3作为启动子标志。研究表明,H3K4me1和H3K4me3与基因激活相关,H3K4me3主要富集在转录起始位点附近的启动子区域,而大多数H3K4me1修饰富集在增强子区域;H3K27ac与基因激活相关,主要富集在增强子和启动子区域,当增强子区只有H3K4me1修饰富集时,该增强子处于平衡状态,而当增强子区域同时富集H3K4me1和H3K27ac修饰时,该增强子就处于激活状态促进基因表达;H3K27的甲基化是可逆的过程,H3K27me1显示出对转录具有正向影响,启动子区域的H3K27me3甲基化修饰时抑制基因的转录,而H3K27me2广泛分布并且在沉默非细胞类型特异性增强子中起作用。

下表为常见的组蛋白修饰的主要分布及功能:

image

异染色质是染色质的浓缩,转录无活性状态,H3K9甲基化是异染色质的标志。H3K27me1和H3K9me3存在于着丝粒异染色质区域,而H3K27me3和H3K9me2共同存在于抑制的常染色质区域中。H3K9ac也与H3K14ac和H3K4me3高度共存共同作为活性基因启动子的标志。

本次实践文章:
Targeting super-enhancer-associated oncogenes in oesophageal squamous cell carcinoma
用不同浓度的OSCC抗癌物THZ1处理两种OSCC细胞系:KYSE510和TE7。
寻找药物处理后的超级增强子。

1.下载SRA原始数据:

#!/bin/bash
for ((i=251;i<=254;i++))
do wget https://sra-download.ncbi.nlm.nih.gov/traces/sra28/SRR/003028/SRR3101$i
done

2.提取fastq文件:

#!/bin/bash
for i in SRR310125*
do
        echo $i
        fastq-dump --gzip --split-files $i
done

每运行一个文件,都会在家目录下的ncbi文件里生成一个临时文件,非常占内存。由于我的存储空间没有了,所以我就直接下载了fastq文件。下载fastq文件的网址是:https://www.ebi.ac.uk/ena/data/view/SRX1530372。再复制下fastq.gz文件的地址。
网上有的文章提到:尽量不要用wget或curl去下载sra文件,某些情况下会导致下载的文件不完整。所以这次我也尝试了用ascp下载的方法。
这里说一下用ascp下载的方法。

安装ASCP:

#下载
$ wget http://download.asperasoft.com/download/sw/connect/3.7.4/aspera-connect-3.7.4.147727-linux-64.tar.gz
$ tar zxvf aspera-connect-3.7.4.147727-linux-64.tar.gz
#安装
$ bash aspera-connect-3.7.4.147727-linux-64.sh
#要去home目录里查看是否有.aspera文件夹
$ cd /home
$ ls -a 
#如果看到.aspera文件夹,代表安装成功
#永久添加环境变量
$ echo 'export PATH=~/.aspera/connect/bin:$PATH' >> ~/.bashrc
$ source ~/.bashrc
#查看是否可以调用
$ ascp --help

ascp的用法:ascp [参数] 目标文件 目标地址在线文档
ascp命令的常用参数:
-v verbose mode 唠叨模式,能让你实时知道程序在干啥,方便查错。
-T 取消加密,否则有时候数据下载不了。
-i 提供私钥文件的地址。
-l 设置最大传输速度,一般200m到500m,如果不设置,反而速度会比较低,可能有个较低的默认值。
-k 断点续传,一般设置为值1
-Q 一般加上它
-P 提供SSH port,一般是33001。

在EBI网站copy下载地址一般是ftp://ftp.sra.ebi.ac.uk/vol1/fastq/SRR310/004/SRR3101254/SRR3101254.fastq.gz这样的格式。需要把ftp://ftp.sra.ebi.ac.uk换成era-fasp@fasp.sra.ebi.ac.uk:。NOTE: 这篇文章的ChIP-seq是单端测序。
我的代码:

$ ascp -QT -l 300m -P33001 -i ~/.aspera/connect/etc/asperaweb_id_dsa.openssh era-fasp@fasp.sra.ebi.ac.uk:/vol1/fastq/SRR310/001/SRR3101251/SRR3101251.fastq.gz .
$ ascp -QT -l 300m -P33001 -i ~/.aspera/connect/etc/asperaweb_id_dsa.openssh era-fasp@fasp.sra.ebi.ac.uk:/vol1/fastq/SRR310/002/SRR3101252/SRR3101252.fastq.gz .
$ ascp -QT -l 300m -P33001 -i ~/.aspera/connect/etc/asperaweb_id_dsa.openssh era-fasp@fasp.sra.ebi.ac.uk:/vol1/fastq/SRR310/003/SRR3101253/SRR3101253.fastq.gz .
$ ascp -QT -l 300m -P33001 -i ~/.aspera/connect/etc/asperaweb_id_dsa.openssh era-fasp@fasp.sra.ebi.ac.uk:/vol1/fastq/SRR310/004/SRR3101254/SRR3101254.fastq.gz .

另外要注意的是:era-fasp@fasp.sra.ebi.ac.uk后面是:号,不是路径
最后gz结尾有一个空格,然后是"."。如果没有空格和点,则会报错。无法下载。

3.使用fastqc质量检查
4.bowtie2比对

下面这些代码是按照上一次实践的方法写的,直接生成bam文件。因为这篇文献的测序结果质量很好,所以没有去掉3'端的几个碱基
#!/bin/bash
bowtie2 -p 6 -x /media/yanfang/FYWD/CHIPSEQ/fqfile/bowtie2hg19/hg19 -U /media/yanfang/FYWD/CHIPSEQ/fqfile/SRR3101251.fastq.gz | samtools sort -O bam -o /media/yanfang/FYWD/CHIPSEQ/sambam/TE7_H3K27Ac.bam
bowtie2 -p 6 -x /media/yanfang/FYWD/CHIPSEQ/fqfile/bowtie2hg19/hg19 -U /media/yanfang/FYWD/CHIPSEQ/fqfile/SRR3101252.fastq.gz | samtools sort -O bam -o /media/yanfang/FYWD/CHIPSEQ/sambam/TE7_input.bam
bowtie2 -p 6 -x /media/yanfang/FYWD/CHIPSEQ/fqfile/bowtie2hg19/hg19 -U /media/yanfang/FYWD/CHIPSEQ/fqfile/SRR3101253.fastq.gz | samtools sort -O bam -o /media/yanfang/FYWD/CHIPSEQ/sambam/KYSE510_H3K27Ac.bam
bowtie2 -p 6 -x /media/yanfang/FYWD/CHIPSEQ/fqfile/bowtie2hg19/hg19 -U /media/yanfang/FYWD/CHIPSEQ/fqfile/SRR3101254.fastq.gz | samtools sort -O bam -o /media/yanfang/FYWD/CHIPSEQ/sambam/KYSE510_input.bam
下面这些代码是bowtie2比对后生成sam文件的方法。有些文章里在进行比对的时候是用的bowtie进行比对的,并且设置了只保留比对一次的reads。我这里用的是bowtie2,所以没有设置这个参数。
#!/bin/bash
bowtie2 -p 6 -x /media/yanfang/FYWD/CHIPSEQ/fqfile/bowtie2hg19/hg19 -U /media/yanfang/FYWD/CHIPSEQ/fqfile/SRR3101251.fastq.gz -S TE7_H3K27Ac.sam
bowtie2 -p 6 -x /media/yanfang/FYWD/CHIPSEQ/fqfile/bowtie2hg19/hg19 -U /media/yanfang/FYWD/CHIPSEQ/fqfile/SRR3101252.fastq.gz -S TE7_input.sam
bowtie2 -p 6 -x /media/yanfang/FYWD/CHIPSEQ/fqfile/bowtie2hg19/hg19 -U /media/yanfang/FYWD/CHIPSEQ/fqfile/SRR3101253.fastq.gz -S KYSE510_H3K27Ac.sam
bowtie2 -p 6 -x /media/yanfang/FYWD/CHIPSEQ/fqfile/bowtie2hg19/hg19 -U /media/yanfang/FYWD/CHIPSEQ/fqfile/SRR3101254.fastq.gz -S KYSE510_input.sam
#比对率如下:
64273075 reads; of these:
  64273075 (100.00%) were unpaired; of these:
    1285733 (2.00%) aligned 0 times
    46680241 (72.63%) aligned exactly 1 time
    16307101 (25.37%) aligned >1 times
98.00% overall alignment rate
[bam_sort_core] merging from 16 files and 1 in-memory blocks...
64402758 reads; of these:
  64402758 (100.00%) were unpaired; of these:
    1271927 (1.97%) aligned 0 times
    45320875 (70.37%) aligned exactly 1 time
    17809956 (27.65%) aligned >1 times
98.03% overall alignment rate
[bam_sort_core] merging from 16 files and 1 in-memory blocks...
64555367 reads; of these:
  64555367 (100.00%) were unpaired; of these:
    901311 (1.40%) aligned 0 times
    48336949 (74.88%) aligned exactly 1 time
    15317107 (23.73%) aligned >1 times
98.60% overall alignment rate
[bam_sort_core] merging from 16 files and 1 in-memory blocks...
68947224 reads; of these:
  68947224 (100.00%) were unpaired; of these:
    4955211 (7.19%) aligned 0 times
    45955461 (66.65%) aligned exactly 1 time
    18036552 (26.16%) aligned >1 times
92.81% overall alignment rate
[bam_sort_core] merging from 17 files and 1 in-memory blocks...

5.使用MACS获得Chip-seq富集区
以下是官方网站对于常规峰和“宽”峰的一些解释(https://www.encodeproject.org/chip-seq/histone/) 。有的文章说常规峰和宽峰分析过程会有些不一样,所以我特异查了一下H3K27Ac是什么峰,根据这个表来看属于常规峰。

  • For narrow-peak histone experiments, each replicate should have 20 million usable fragments.
  • For broad-peak histone experiments, each replicate should have 45 million usable fragments.
  • H3K9me3 is an exception as it is enriched in repetitive regions of the genome. Compared to other broad marks, there are few H3K9me3 peaks in non-repetitive regions of the genome in tissues and primary cells. This results in many ChIP-seq reads that map to a non-unique position in the genome. Tissues and primary cells should have 45 million total mapped reads per replicate.
image.png
$ macs2 callpeak -c /media/yanfang/FYWD/CHIPSEQ/sambam/TE7_input.bam -t /media/yanfang/FYWD/CHIPSEQ/sambam/TE7_H3K27Ac.bam -m 10 30 -p 1e-5 -f BAM -g hs -n TE7_H3K27Ac 2>TE7_H3K27Ac.masc2.log
$ macs2 callpeak -c /media/yanfang/FYWD/CHIPSEQ/sambam/KYSE510_input.bam -t /media/yanfang/FYWD/CHIPSEQ/sambam/KYSE510_H3K27Ac.bam -m 10 30 -p 1e-5 -f BAM -g hs -n KYSE510_H3K27Ac 2>KYSE510_H3K27Ac.masc2.log

-c:对照组。
-t:处理组。
--format:输入的文件类型。
--输出的文件前缀名称。
--keep-dup对于重复序列的处理方式,1效果最好。指明MACS在染色体同一位置的reads(重复序列处理方式)。
--wig:输出的文件类型。
--single-profile表示输出单文件。
--space是文献中的要求。(Wiggle files were generated using read pileups for every 50 base pair bins)
--m:This parameter is used to select the regions within MFOLD range of high-confidence enrichment ratio against background to build model. The regions must be lower than upper limit, and higher than the lower limit of fold enrichment. DEFAULT:10,30 means using all regions not too low (>10) and not too high (<30) to build paired-peaks model. If MACS can not find more than 100 regions to build model, it will use the --shiftsize parameter to continue the peak detection.This parameter is used to select the regions within MFOLD range of high-confidence enrichment ratio against background to build model. The regions must be lower than upper limit, and higher than the lower limit of fold enrichment. 构建双峰模型时使用,默认[10,30]。表示选择那些倍数变化在10-30之间的富集区域,如果找不到100个区域构建模型,并且你还设置了--fix-biomodal,它就会用--shiftsize参数继续分析。

call peak 后得到以下几个文件类型:


image.png

打开peak.xls文件后,表头有几行显示:

image.png

6.构建index文件
为了在IGV里查看peak,需要把bam文件先构建index,即生成bam.bai文件:

$ samtools index TE7_H3K27Ac.bam TE7_H3K27Ac.bam.bai
$ samtools index TE7_input.bam TE7_input.bam.bai
$ samtools index KYSE510_H3K27Ac.bam KYSE510_H3K27Ac.bam.bai
$ samtools index KYSE510_input.bam KYSE510_input.bam.bai

顺便插一句:[生信人必会之samtools](https://vip.biotrainee.com/d/117-samtools
这篇文章大概是我看到过写的最好最全面的samtool使用方法。
7.用deeptools里的bamcoverage工具将bam文件标准化

$ bamCoverage -b TE7_H3K27Ac.bam -o TE7_H3K27Ac.bw -p 10 --normalizeUsing RPKM
$ bamCoverage -b TE7_input.bam -o TE7_input.bw -p 10 --normalizeUsing RPKM
$ bamCoverage -b KYSE510_H3K27Ac.bam -o KYSE510_H3K27Ac.bw -p 10 --normalizeUsing RPKM
$ bamCoverage -b KYSE510_input.bam -o KYSE510_input.bw -p 10 --normalizeUsing RPKM

将生成的bw文件(标准化后的)导入IGV:

这是文献里IRF6基因附近的peak富集情况
这是我自己做的IRF6基因附近的富集情况
这是文献里TP63基因附近的peak富集情况
这是我自己做的TP63基因附近peak的富集情况

其他文献里涉及到的IGV的图,都几乎和我做出来的一模一样,说明分析过程基本没啥问题。

7.ROSE筛选super-enhancer
这部分是本次实践的重点,ROSE官网:http://younglab.wi.mit.edu/super_enhancer_code.html
有关这个ROSE软件讲解的比较好的中文版的文章:https://blog.csdn.net/oxygenjing/article/details/77862115
ROSE的最主要用法有ROSE_main.py和ROSE_geneMapper.py。其中ROSE_main.py 用于寻找增强子而ROSE_geneMapper.py 用于为增强子相关的基因进行注释。

首先看一下ROSE_mian.py 用法:

(1)安装ROSE,我们直接从其托管在Bitbucket仓库中克隆Python脚本

git clone https://bitbucket.org/young_computation/rose.git

也可以像这篇文章一样https://blog.csdn.net/oxygenjing/article/details/77862115,安装ROSE

$ wget https://bitbucket.org/young_computation/rose/get/1a9bb86b5464.zip
$ unzip 1a9bb86b5464.zip

(2)安装后,首先准备文件:peaks的gff文件。这个peak文件是MACS2 call peak之后生成的peaks文件。
官方网站对gff文件的格式要求:
.gff must have the following columns:
1: chromosome (chr#)
2: unique ID for each constituent enhancer region
4: start of constituent
5: end of constituent
7: strand (+,-,.)
9: unique ID for each constituent enhancer region
所以要先从peak文件里提取这些要用的列。这里要注意的是:1,2,4,5,7,9是gff文件的列数,第3,6,8列不是不要了,而是要都写成“ ”空格形式。
(刚开始我以为其他三列都不要了,所以在gff文件里只有6列,结果一直报错。后来按照某篇教程里写的其他三列都换成".",结果也一直报错......整整折腾了我3天的时间,死活跑不通。)

$ awk '{print $1"\t"$10"\t"" ""\t"$2"\t"$3"\t"" ""\t"".""\t"" ""\t"$10}' TE7_H3K27Ac_peaks.bed > TE7_peaks.gff

这里的\t是以制表符分割的意思。每一列用\t分割,并且用""括起来。

(3)接下来创建一个虚拟的python2.7的环境,因为我装的是python3,所以需要创建一个虚拟的环境来运行ROSE。

source activate py27

(4)还需要将samtools的PATH设置到这个文件夹里,因为ROSE运行时需要调用samtools。如果你的samtool没有设置全局变量,是要多一步添加PATH的。但是因为我的samtool已经在全局变量里,可以直接在这个文件夹里打"samtools"就可以调用,所以我就没有再设置环境变量了。

(5)之后我们需要bam文件(这个bam文件是需要先sort的。处理组,对照组),gff文件(处理组),bam.bai文件(也就是bam的index文件,处理组和对照组)。把这些文件全都放进ROSE安装的文件夹里,切记:运行ROSE的时候也要在其安装的文件夹里运行,我也不知道这软件开发的人是咋想的。。。

然后一切准备好之后,就是见证奇迹的时刻了。(虽然我这个奇迹到了第4天才看到。。。之前3.9天都在解决报错问题了)

python ROSE_main.py -g HG19 -i ./TE7/TE7_peaks.gff -r ./TE7/TE7_H3K27Ac_sorted.bam -c ./TE7/TE7_input_sorted.bam -o roseresult -s 12500 -t 2500

如果运行时有报错,例如有类似如下显示:

Traceback (most recent call last):
  File "ROSE_bamToGFF.py", line 249, in <module>
    main()
  File "ROSE_bamToGFF.py", line 240, in main
    newGFF = mapBamToGFF(bamFile,gffFile,options.sense,int(options.extension),options.floor,options.rpm,options.matrix)
  File "ROSE_bamToGFF.py", line 76, in mapBamToGFF
    gffLocus = ROSE_utils.Locus(line[0],int(line[3]),int(line[4]),line[6],line[1])

请确保你的bam文件格式,gff文件格式,samtool的环境变量都没有问题的情况下,并且所有需要的文件在ROSE安装的文件夹里,仍然出现这些报错,你可以尝试这样修改源代码:(参考官方给出的解决方法:https://bitbucket.org/young_computation/rose/issues/44/typeerror-issue
FIX:
Make the following changes to ROSE_utils.py:
Line 602 (original): command = 'samtools view %s | head -n 1' % (bamFile)
Line 602 (new): command = './samtools view %s | head -n 1' % (bamFile)
Line 632 (original): command = 'samtools flagstat %s' % (self._bam)
Line 632 (new): command = './samtools flagstat %s' % (self._bam)
Line 657 (original): command = 'samtools view %s %s' % (self._bam,locusLine)
Line 657 (new): command = './samtools view %s %s' % (self._bam,locusLine)

最后运行后会生成很多文件:

image.png

输出文件如下(参考文章:https://blog.csdn.net/oxygenjing/article/details/77862115):
1.gtf(这个文件在gff文件夹里): 该文件为输入gtf文件的副本。

2.stitched.gtf(这个文件也在gff文件夹里):该文件为通过STITCHING_DISTANCE将INPUT_CONSTITUENT_GFF拼接在一起创建的gff文件;文件列数如下:
chrom, name, [blank], start, end, [blank], [blank], strand, [blank], [blank], name
其中 name 字段的命名方式为:拼接起来的区域数+最左端区域ID。

3._MAPPED.gff(在mappedGFF文件夹里): 每个bam文件通过bamToGFF的输出文件,包含以下列:
(成分ID,测试区域,平均读取密度(单位为每百万位元每百万映射的单位读数密度))

4.* _STITCHED * _MAPPED.gff(在mappedGFF文件夹里,处理组和对照组分别有一个文件): 每个bam文件通过bamToGFF的输出文件,该文件中对增强子区域进行了拼接,包含以下列:
(拼接增强子ID,测试区域,平均读取密度(单位为百万映射每单位拼接增强子数))

5.STITCHED_ENHANCER_REGION_MAP.txt: 利用bamToGFF计算后得到的拼接enhancer密度文件,包含以下列:
(拼接增强子ID,染色体,拼接增强子起始位置,拼接增强子末端位置,拼接数,BAM信号等级,BAM信号)

  1. AllEnhancers.table.txt:enhancer列表,包含每个增强子的排名和是否为超级增强子,内容包括:增强子ID,染色体,拼接增强子起始位点,拼接增强子末端,拼接数,拼接成分大小,BAM的信号,BAM的等级,是否为超增强子:是(1)否(0)

7._SuperEnhancers.table.txt: 超级enhancer的排名,为_AllEnhancers.table.txt 文件的子集。包含以下列:
(拼接增强剂ID,染色体,拼接增强子起始位点,拼接增强子末端,拼接数,缝合在一起的成分的大小,RANKING_BAM的信号,RANKING_BAM的等级,超增强子的二进制(1)与典型(0))

8._Enhancers_withSuper.bed 可以加载到UCSC浏览器中可视化的enhancer bed文件

其中那个png图片就是我们需要的:所有enhancer的散点图

所有enhancer的散点图。其他有的教程这个横坐标和纵坐标是我的两倍,不知道是不是因为用的MACS版本不一样造成的。他们用的是MACS做的call peak。我用的是MACS2做的。

之后是KYSE510细胞系的:

python ROSE_main.py -g HG19 -i ./KYSE510_peaks.gff -r ./KYSE510_H3K27Ac_sorted.bam -c ./KYSE510_input_sorted.bam -o KYSE510_roseresult -s 12500 -t 2500
image.png

8.ROSE注释enhancer

python ROSE_geneMapper.py -i ./TE7_roseresult/TE7_peaks_AllEnhancers.table.txt -g HG19 -o ./TE7_roseresult 2> ./TE7_roseresult/TE7_enhancer_anno.log
python ROSE_geneMapper.py -i ./KYSE510_roseresult/KYSE510_peaks_AllEnhancers.table.txt -g HG19 -o ./KYSE510_roseresult 2> ./KYSE510_roseresult/KYSE510_enhancer_anno.log

得到以下两个表格:

image.png

1.ENHANCER_TO_GENE.txt: enhancer重叠基因、附近基因以及最近的基因列表
2.GENE_TO_ENHANCER.txt: 以每个基因为列名的和其相关的增强子位置信息列表(https://blog.csdn.net/oxygenjing/article/details/77862115

9.利用R做GO富集分析
这部分我也是新手,不知道过程是否正确,反正是跑通了,对不对的还需再多看看。。。
首先在上一步里,我得到了_peaks_AllEnhancers_GENE_TO_ENHANCER.txt这个表,我用的这个表进行的GO分析。

>library(clusterProfiler)
>library(DOSE)
>library(org.Hs.eg.db)
#TE7的enhancer GO富集分析
#首先读取文件,第一行作为列名
>enhancer.relate.gene<-read.table(file="TE7_peaks_AllEnhancers_GENE_TO_ENHANCER.txt",header=T)
#因为在这个txt里的最后一列注明是否为super enhancer,如果是则为1;如果不是则空白。所以取为1的所有行,即挑选出所有的super enhancer
>gene<-enhancer.relate.gene[which(enhancer.relate.gene$IS_SUPER=='1'),]
#查看super enhancer的数据集
> head(gene)
  GENE_NAME REFSEQ_ID                                PROXIMAL_ENHANCERS ENHANCER_RANKS IS_SUPER
1     LAMA5 NM_005560                           chr20:60924936-60956028              1        1
2     RPS21 NM_001024                           chr20:60924936-60956028              1        1
3 C20orf151 NM_080833                           chr20:60924936-60956028              1        1
4     ADRM1 NM_007002                           chr20:60924936-60956028              1        1
5   CABLES2 NM_031215                           chr20:60924936-60956028              1        1
6    MIR205 NR_029622 chr1:209528209-209591314,chr1:209607925-209609032         2,1441        1
#将这个super enhancer的table第一列提出来,因为第一列是基因名。
gene_name<- gene[,1]
#查看基因名
head(gene_name)
[1] "LAMA5"     "RPS21"     "C20orf151" "ADRM1"     "CABLES2"   "MIR205" 
#调用R包
library("stringr") 
library("clusterProfiler")
#GO的BP分析
ego_bp <- enrichGO(gene_name,
                   OrgDb      = org.Hs.eg.db,
                   keyType    = 'SYMBOL',
                   ont        = "BP",
                   pAdjustMethod = "BH",
                   pvalueCutoff = 0.001,
                   )
#泡泡图
dotplot(ego_bp, font.size=10)
泡泡图
#GO图
plotGOgraph(ego_bp)
GO图
#bar图
barplot(ego_bp,showCategory = 10,title="The GO_BP enrichment analysis of all super enhancers-related genes in TE7")+ 
  scale_size(range=c(2, 12))+
  scale_x_discrete(labels=function(ego_bp) str_wrap(ego_bp,width = 25))
image.png

KYSE510的分析过程和结果我就不放进来了,只需要把输入的文件换掉就行,其他的一模一样。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
禁止转载,如需转载请通过简信或评论联系作者。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容