Python数据类型之数字与字符串

Python数据类型概览

python3中有六个标准的数据类型,分别为:①Number(数字);②String(字符串);③List(列表);④Tuple(元组);⑤Sets(集合);⑥Dictionary(字典)。

根据能否更改这些类型变量的值,可以把这六个标准类型划分为两类:

第一类:不可变数据(四个):Number(数字)、String(字符串)、Tuple(元组)、Sets(集合);

第二类:可变数据(两个):List(列表)、Dictionary(字典)。

根据不同类型的数据内的元素是否有顺序,还可以划分两类:

第一类:有序序列:列表,元组,字符串;

第二类:无序序列:字典,集合。

变量的赋值

Python中变量要遵循一定的规则,例如不得以数字开头,不得以Python关键字作为变量。此外,Python还提供了一个函数用于判断一个字符串能否作为变量的名称,即isidentifier(),如下所示:

>>> 'abc'.isidentifier()
True
>>> '3abc'.isidentifier()
False

常规赋值操作

Python使用等号(=)给变量赋值,等号(=)运算符左边是一个变量名,等号(=)运算符右边是存储在变量中的值,如下所示:

biotest@biotest-VirtualBox:~/python3/01basic$ cat variable.py 
#!/usr/bin/python3

counter = 100
miles = 1000.00
name = "runoob"

print(counter)
print(miles)
print(name)
biotest@biotest-VirtualBox:~/python3/01basic$ python3 variable.py 
100
1000.0
runoob

多变量赋值

Python可以同时对多个变量进行赋值,如下所示:

a = b = c =1

或者像这样:

a, b, c = 1, 2, "runoob"

这种赋值试方式,就是相当于a = 1, b = 2, c = "runoob"

判断是否是同一个对象——is

两个变量是否指向的是同一个对象,可以用is 运算符,如下所示:

>>> a = 'banana'
>>> b = 'banana'
>>> a is b
True
>>> b is a
True

Number(数字)

类型判断函数type()

Python3中的数字类型具体包括int(整型)float(浮点型)bool(布尔型)complex(复数型)这四种。使用内置的type()函数可以查看对象的类型,如下所示:

>>> a, b, c, d = 20, 5.5, True, 4+4j
>>> print(type(a), type(b), type(c), type(d))
<class 'int'> <class 'float'> <class 'bool'> <class 'complex'>
>>>

类型判断函数instance()

还可以通过instance函数来判断,这个函数的使用格式为instance(a,b),即判断a是否是b的一个实例,如下所示:

>>> a = 111
>>> isinstance(a, int)
True
>>> isinstance(a, float)
False

isinstancetype()的区别可以通过一些代码来看:

biotest@biotest-VirtualBox:~/python3/01basic$ cat type_instance_diff.py 
#!usr/bin/python3

class A:
    pass

class B(A):
    pass

print(isinstance(A(),A))
print(type(A()) == A)
print(isinstance(B(),A))
print(type(B()) == A)

biotest@biotest-VirtualBox:~/python3/01basic$ python3 type_instance_diff.py 
True
True
True
False

区别就是,type()认为子类与父类不是一个类型,isinstance()认为子类与父类是一个类型。

字符串转换为整型

不同类型的变量有时候会出现错误,如下所示:

>>> num = 1
>>> string = '1'
>>> print(num + string)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: unsupported operand type(s) for +: 'int' and 'str'

因此,只要在一段代码中要涉及不同类型的变量,最好使用type()函数来查看一下数据类型。如果不同,有时候需要进行类型转换,如下所示:

>>> num = 1
>>> string = '1'
>>> num2 = int(string)
>>> print(num +num2)
2

变量的删除

变量的删除使用del函数。

字符串

字符串的访问

字符串就是一串有序的字符。你可以通过方括号操作符,每次去访问字符串中的一个字符,如下所示:

>>> fruit = 'banana'
>>> letter = fruit[1]
>>> letter
'a'

其中[1]是索引,用于指示字符串中字符的位置,python中第1个位置是[0],而非[1]。

字符串的长度

len是一个内置函数,会返回一个字符串中字符的长度:

>>> len(fruit)
6
>>> len(letter)
1
>>> fruit[len(fruit)-1] #返回fruit的最后一个字母
'a'

字符串的加法

字符串的加法就是将字符串连接起来,如下所示:

>>> what_he_does = ' plays '
>>> his_instrument = 'guitar'
>>> his_name = 'Robert Johnson'
>>> artist_intro = his_name + what_he_does + his_instrument
>>> print(artist_intro)
Robert Johnson plays guitar

字符串无法修改

字符串属于不可变序列,无法进行修改,如下所示:

>>> greeting = 'Hello, world!'
>>> greeting[0] = 'J'
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: 'str' object does not support item assignment

但是可以新建一个字符串,如下所示:

>>> greeting = 'Hello, world!'
>>> new_greeting = 'J' + greeting[1:]
>>> print(new_greeting)
Jello, world!

在Python中处理这类无法修改的数据类型时,通常的做法就是提取相应的字符串,然后再新建一个。

字符串的切片与索引

先看一个案例,如下所示:

>>> name = 'My name is Mike'
>>> print(name[0]) # 切下第0个元素
M
>>> print(name[-4]) # 切下倒数第4个元素
M
>>> print(name[11:14]) # 切下第11到第14个元素,左闭右开区间
Mik
>>> print(name[11:15]) # 切下第11到第15个元素,左闭右开区间
Mike
>>> print(name[5:]) # 从第5个元素开始切,一直到结尾
me is Mike
>>> print(name[:5]) # 从第0个元素开始切,不包括第5个元素,左闭右开区间
My na

字符串每个字符对应的索引:

[图片上传失败...(image-8ec9db-1551584517626)]

再看另外一个案例,下面的这个案例中使用了几个参数,如下所示:

>>> b = 'ACTGCATCATC'
>>> b[0:3] # 截取0到3元素
'ACT'
>>> b[2:4] # 截取2到4元素
'TG'
>>> b[2:-1] # 截取第2到最后一个元素
'TGCATCAT'
>>> b[2:] # 截取第2到最后一个元素
'TGCATCATC'
>>> b[::-1] # #创造一个与原字符串顺序相反的字符串
'CTACTACGTCA'
>>> b[-3:-1] #截取倒数第三位与倒数第一位之前的字符
'AT'
>>> b[-3:] #截取倒数第三位到结尾
'ATC'
>>> b[:-5:-3] #逆序截取
'CC'
>>> b[::2]   # 隔一个取一个元素的操作
'ATCTAC'
>>> b[0:6:2] # 截取第0到第6个元素,然后再间隔1个取元素
'ATC'
>>> b[9:0:-3] # 截取第0到第9个元素,然后倒序间隔取3个元素
'TTG'
>>>

字符串的分割

这里要与字符串的切片区分,字符串的分割使用的是split(),如下所示:

>>> s = 'pining for the fjords'
>>> t = s.split()
>>> t
['pining', 'for', 'the', 'fjords']

可选的参数是定界符,是用来确定单词边界的。下面这个例子中就是把连接号-作为定界符:

>>> s = 'spam-spam-spam'
>>> delimiter = '-'
>>> t = s.split(delimiter)
>>> t
['spam', 'spam', 'spam']

字符串的拼接

join是与split功能相反的一个方法。它接收一个字符串列表,然后把所有元素拼接到一起。join是一个字符串方法,所以必须把 join放到定界符后面来调用,并且传递一个列表作为参数:

>>> t = ['pining','for','the','fjords']
>>> delimiter = ' '
>>> s = delimiter.join(t)
>>> s
'pining for the fjords'

替换某字符串

这里用到了字符串的replace()方法,这个方法是用某个字符替换某个字符,虽然是替换,但是原字符是不变的,只是将替换后的字符赋值给了一个新的变量,如下所示:

>>> phone_number = '1386-666-0006'
>>> hiding_number = phone_number.replace(phone_number[:9],'*'*9)
>>> print(hiding_number)
*********0006

字符串计数

下面的这段代码是统计在banana这个单词有多少个a,如下所示:

>>> word = "banana"
>>> count = 0
>>> for letter in word:
... if letter == 'a':
... count = count + 1
...
>>> print(count)
3

除了函数形式外,还可以使用count()方法,如下所示:

>>> word = "banana"
>>> word.count('a')
3

查询字符串

查询字符常用的方法是find()rfind()index()。其中,find()rfind()的区别在于,一个是在左边开始查找,一个在右边开始查找(r就是right的意思),index()法检测字符串中是否包含子字符串str,如果指定beg(开始) 和end(结束) 范围,则检查是否包含在指定范围内,该方法与 python find()方法一样,只不过如果str不在 string中会报一个异常。find()rfind()查找一个字符串在另一个字符串指定范围(默认是整个字符串)中首次出现的位置,如果不存在,返回-1,存在返回1,如下所示:

>>> s = 'apple, peach, banana, peach, pear'
>>> s.find("peach")
7
>>> s = 'apple, peach, banana, peach, pear'
>>> s.find("peach") # 返回第一次出现的位置
7
>>> s.find("peach",7) # 在指定位置开始查找
7
>>> s.find("peach",7,20) # 在指定范围内进行查找
7
>>> s.rfind('p') # 从字符串尾部向前查找
29
>>> s.index('p') # 返回首次出现的位置
1
>>> s.index('pe')
7
>>> s.index('pear')
29
>>> s.index('ppp') # 指定子字符串不存在时抛出异常
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: substring not found

再看一个查询电话号码的案例:

>>> search = '168'
>>> num_a = '1386-168-0006'
>>> num_b = '1681-222-0006'
>>> print(search + ' is at ' + str(num_a.find(search)) + ' to '+str(num_a.find(search) + len(search)) + ' of num_a')
168 is at 5 to 8 of num_a
>>> print(search + ' is at ' + str(num_b.find(search)) + ' to '+str(num_b.find(search) + len(search)) + ' of num_b')
168 is at 0 to 3 of num_b

查询某字母

方法与前面的类似,如下所示:

>>> word = 'banana'
>>> index = word.find('a')
>>> print(index)
1

in运算

in 这个词在字符串操作中是一个布尔操作符,它读取两个字符串,如果前者的字符串为后者所包含,就返回真,否则为假:

>>> 'a' in 'banana'
True
>>> 'seed' in 'banana'
False

删除字符串中的空格

使用的strip()方法,如下所示:

>>> mybag = [' glass',' apple','green leaf ']
>>> #有的前面有空格,有的后面有空格
... print([one.strip() for one in mybag])
['glass', 'apple', 'green leaf']
>>> #去掉元素前后的空格
... ['glass', 'apple', 'green leaf']
['glass', 'apple', 'green leaf']

遍历所有字符串

使用的是for循环,第一种方法,使用索引,如下所示:

>>> index = 0
>>> fruit = "banana"
>>>
>>> while index < len(fruit):
... letter = fruit[index]
... print(letter)
... index = index +1
...
b
a
n
a
n
a

第二种方法,直接使用字符串,如下所示:

>>> fruit = "banana"
>>> for letter in fruit:
... print(letter)
...
b
a
n
a
n
a

字符串的复制

直接使用乘法就行,如下所示:

>>> words = 'word'*4
>>> print(words)
wordwordwordword
wordwordwordword

字符串的 大小转换,首字母大写

符串提供了一些方法,这些方法能够进行很多有用的操作。方法和函数有些类似,也接收参数然后返回一个值,但语法稍微不同。比如,upper这个方法就读取一个字符串,返回一个全部为大写字母的新字符串。与函数的upper(word)语法不同,方法的语法是word.upper()。后面括号里面是空白的,表示这个方法不接收参数,如下所示:

>>> word = 'banana'
>>> new_word = word.upper()
>>> print(new_word)
BANANA

upper()方法是大写,lower()是小写,capitalize()首字母大写、title()将每个字母变为大写,swapcase()大小写互换,如下所示:

>>> s = "What is Your Name?"
>>> s.lower()
'what is your name?'
>>> s.upper()
'WHAT IS YOUR NAME?'
>>> s.capitalize()
'What is your name?'
>>> s.swapcase()
'wHAT IS yOUR nAME?'

ASCII值的转换

ord()是一个内建函数,能够返回某个字符(注意,是一个字符,而不是多个字符组成的串),所对应的ASCII值(是十进制的),字符a在ASCII中的值是97,空格在ASCII中也有值,是32,反过来,根据整数值得到的相应字符,可以使用chr(),如下所示:

>>> print(ord('a'))
97
>>> print(chr(97))
a
>>> print(chr(98))
b

转义字符

转义字符是指,在字符串中某些特定的符号前加一个斜线之后该字符将被解释为另外一种含义,不再表示本来的字符,常见的转义字符如下所示:

转义字符 含义
\b 退格,把光标移动到前一列位置
\f 换页符
\n 换行符
\r 回车
\t 水平制表符
\v 垂直制表符
\\ 一个\
\' 单引号
\" 双引号
\ooo 3位八制对应的字符
\xhh 2位十六进制对应的字符
\uhhhh 4位十六进制数表示的Unicode字符

使用案例如下所示:

 >>> print('Hello\nWorld')
Hello
World
>>> oct(65)
'0o101'
>>> print('\101') # 3位八进制数对应的字符
A
>>> hex(65)
'0x41'
>>> print('\x41') # 2位十六进制数对应的字符
A
>>> ord('张')
24352
>>> hex(_)
'0x5f20'
>>> print('\u8463') # 4位十六进制数表示的Unicode字符
董

eval函数

eval()是一具内置变数,它可以将任意字符串转化为Python表达式,并进行求值。

>>> eval("3+4") # 计算表达式的值 
7
>>> a = 3
>>> b = 5
>>> eval('a+b') # 这时候要求变量a和b都已经存在
8
>>>

判断某字符串的开头或结尾

startswith(),endswith()用于判断字符串是否以指定字符串开始或结束,可以接收两个整数参数来限定字符串的检测范围,如下所示:

>>> s = 'Beautiful is better than ugly' 
>>> s.startswith('Be') # 检测整个字符串
True
>>> s.startswith('Be',5) # 指定检测范围的起始位置
False
>>> s.startswith('Be',0,5) # 指定检测范围的起始和结束位置
True
>>>

判断字符串的首个字符内容

isalnum(),isalpha(),isdigit(),isdecimal(),isnumeric(),isspace(),isupper(),islower()用于检测字符串是否为数字或字母,是否为字母,是否为数字字符,是否为空白字符,是否为大写字母以及是否为小写字母,如下所示:

>>> '1234abcd'.isalnum()
True
>>> '1234abcd'.isalpha() # 全部为英文字母时返回True
False
>>> '1234abcd'.isdigit() # 全部为数字时返回True
False
>>> 'abcd'.isalpha()
True
>>> '1234.0'.isdigit()
False
>>> '1234'.isdigit()
True
>>> '九'.isnumeric() # isnumeric()方法支持汉字数字
True
>>> '99'.isnumeric()
True
>>> '九'.isdigit()
False
>>> '九'.isdecimal()
False

输出格式美化

Python两种输出值的方式:表达式语句和print()函数。 第三种方式是使用文件对象的write()方法,标准输出文件可以用sys.stdout引用,write()方法在处理文本文件的时候经常使用,如果你希望输出的形式更加多样,可以使用str.format()函数来格式化输出值,如果希望将输出的值转成字符串,可以使用repr()str()函数来实现。 这两个函数区别如下所示:

  1. str():函数返回一个用户易读的表达形式。
  2. repr():产生一个解释器易读的表达形式。

输出格式案例1:

如下所示:

>>> str(s)
'Hello Runoob'
>>> print(type(str(s)))
<class 'str'>
>>> print(type(s))
<class 'str'>
>>> repr(s)
"'Hello Runoob'"
>>> print(type(repr(s)))
<class 'str'>
>>> str(1/7)
'0.14285714285714285'
>>> x = 10*3.25
>>> y=200*200
>>> s = 'The value of x is:  ' + repr(x) + ',the value of y is: ' + repr(y) + '...'
>>> print(s)
The value of x is:  32.5,the value of y is: 40000...
>>> hello = 'hello, runoob\n'
>>> hellos = repr(hello)
>>> print(hellos)
'hello, runoob\n'
>>> repr((x,y,('Google', 'Runoob')))
"(32.5, 40000, ('Google', 'Runoob'))"

输出格式案例2

下面的代码输出一个平方与立方根,如下所示:

>>> for x in range(1,5):
...     print(repr(x).rjust(2),repr(x*x).rjust(3),end=' ') 
# 使用print添加空格,即end=' '
# rjust()表示字符串靠右,并在左边填充空格

...     print(repr(x*x*x).rjust(4))
...
 1   1    1
 2   4    8
 3   9   27
 4  16   64

>>> for x in range(1,5):
...     print('{0:2d} {1:3d}{2:4d}'.format(x,x*x,x*x*x))
...
 1   1   1
 2   4   8
 3   9  27
 4  16  64

输出格式案例第3:

zfill方法表示在数字的左边填充0,如下所示:

>>> '12'.zfill(5)
'00012'
>>> '-3.14'.zfill(7)
'-003.14'
>>> '3.14159265359'.zfill(5)
'3.14159265359'

字符串输出的格式化

字符串的格式化输出有两种方式,一种是使用%符号,另外一种是使用str.format(),下面是使用的一些案例:

>>> print("{:,}".format(123456))
#输出1234,56
123,456
>>> print("{a:w^8}".format(a="8"))
#输出www8wwww
www8wwww
>>> print("%.5f" %5)
#输出5.000000
5.00000
>>> print("%-7s3" %("python"))
#输出python 3
python 3
>>> print("%.3e" %2016)
#输出2.016e+03,也可以写大E
2.016e+03
>>> print("%d %s" %(123456,"myblog"))
#输出123456 myblog
123456 myblog
>>> print("%(what)s is %(year)d" % {"what":"this year","year":2016})
#输出this year is 2016
this year is 2016
>>> print("{0}{1}".format("hello","fun"))
#输出hellofun,这与CSharp的格式化字符(占位符)相似
hellofun
>>> print("{}{}{}".format("spkk",".","cn"))
#输出spkk.cn
spkk.cn
>>> print("{a[0]}{a[1]}{a[2]}".format(a=["spkk",".","cn"]))
#输出spkk.cn
spkk.cn
>>> print("{dict[host]}{dict[dot]}{dict[domain]}".format(dict={"host":"www","domain":"spkk.cn","dot":"."}))
#输出www.spkk.cn
www.spkk.cn
>>> print("{a}{b}".format(a="python",b="3"))
#输出python3
python3
>>> print("{who} {doing} {0}".format("python",doing="like",who="I"))
#输出I like python
I like python

str.format

str.format的基本使用如下所示:

>>> print('{} website: "{}!"'.format('Runobb tuorial','www.runoob.com'))
Runobb tuorial website: "www.runoob.com!"

括号及其里面的字符(称作格式化字段)将会被format()中的参数替换。在括号中的数字用于指向传入对象在format()中的位置,如下所示:

>>> print('{0} and {1}'.format('Google','Runoob'))
Google and Runoob
>>>
>>> print('{1} and {0}'.format('Google','Runoob'))
Runoob and Google

如果在 format() 中使用了关键字参数, 那么它们的值会指向使用该名字的参数,如下所示:

>>> print('{name}website:{site}'.format(name='Runoob tutorial ',site='www.runoob.com'))
Runoob tutorial website:www.runoob.com

位置及关键字参数可以任意的结合:

>>> print('Website list {0},{1}, and {other}. '.format('Google','Runoob',other='Taobao'))
Website list Google,Runoob, and Taobao.

'!a'(使用ascii()),'!s'(使用str())和'!r'(使用repr())可以用于在格式化某个值之前对其进行转化,如下所示:

>>> import math
>>> print('Constant of PI is around:{}.'.format(math.pi))
Constant of PI is around:3.141592653589793.
>>> print('Constant of PI is around:{!r}.'.format(math.pi))
Constant of PI is around:3.141592653589793.

可选项':'和格式标识符可以跟着字段名。这就允许对值进行更好的格式化。下面的例子将Pi保留到小数点后三位,如下所示:

>>> import math
>>> print('Constant PI is about: {0:.3f}.'.format(math.pi))
Constant PI is about: 3.142.

':'后传入一个整数,可以保证该域至少有这么多的宽度。用于美化表格时很有用,如下所示:

>>> table = {'Google':1,'Runoob':2,'Taobao':3}
>>> for name, number in table.items():
...     print('{0:10} ==> {1:10d}'.format(name,number))
...
Google     ==>          1
Runoob     ==>          2
Taobao     ==>          3

如果你有一个很长的格式化字符串, 而你不想将它们分开, 那么在格式化时通过变量名而非位置会是很好的事情。 最简单的就是传入一个字典, 然后使用方括号[]来访问键值 :

>>> table = {'Google':1,'Runoob':2,'Taobao':3}
>>> print('Runoob:{0[Runoob]:d}; Google:{0[Google]:d}; Taobao:{0[Taobao]:d}'.format(table))
Runoob:2; Google:1; Taobao:3

也可以通过在 table 变量前使用**来实现相同的功能:

>>> table = {'Google':1,'Runoob':2,'Taobao':3}
>>> print('Runoob:{Runoob:d};Google:{Google:d};Taobao:{Taobao:d}'.format(**table))
Runoob:2;Google:1;Taobao:3

%用于格式化输出

格式化字符串时,Python使用一个字符串作为模板。模板中有格式符,这些格式符为真实值预留位置,并说明真实数值应该呈现的格式。Python用一个tuple将多个值传递给模板,每个值对应一个格式符。%的格式化输出如下所示:

>>> print("I'm %s. I'm %d year old" % ('Vamei', 99)) 
I'm Vamei. I'm 99 year old

它的用法如下图所示:

[图片上传失败...(image-b4c143-1551584517626)]

格式符汇总

格式符为真实值预留位置,并控制显示的格式。格式符可以包含有一个类型码,用以控制显示的类型,如下所示:

%s 字符串 (采用str()的显示)
%r 字符串 (采用repr()的显示) 
%c 单个字符 
%b 二进制整数 
%d 十进制整数 
%i 十进制整数 
%o 八进制整数 
%x 十六进制整数 
%e 指数 (基底写为e) 
%E 指数 (基底写为E) 
%f 浮点数 
%F 浮点数,与上相同 
%g 指数(e)�或浮点数 (根据显示长度) 
%G 指数(E)或浮点数 (根据显示长度)

格式符号进阶

格式符号还可以按如下方式进行使用:

1. %[(name)][flags][width].[precision]typecode 
2. (name)为命名 
3. flags可以有+,-,' '或0。+表示右对齐。-表示左对齐。' '为一个空格,表示在正数的左侧填充一个空格,从而与负数对齐。0表示使用0填充。 
4. width表示显示宽度 
5. precision表示小数点后精度

使用案例如下所示:

>>> print("%+10x" % 10)
        +a
>>> print("%04d" % 5)
0005
>>> print("%6.3f" % 2.3)
 2.300

上面的width, precision为两个整数。我们可以利用*,来动态代入这两个量。比如:

>>> print("%.*f" % (4, 1.2))
1.2000

Python实际上用4来替换*。所以实际的模板为%.4f:

>>> print("%.4f" % (1.2))
1.2000

参考资料

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

推荐阅读更多精彩内容