字符串(2)
最后更新于:2022-04-01 11:34:15
## raw_input和print
自从本课程开始以来,我们还没有感受到computer姑娘的智能。最简单的智能应该体现在哪里呢?想想小孩子刚刚回说话的时候情景吧。
> 小孩学说话,是一个模仿的过程,孩子周围的人怎么说,她(他)往往就是重复。看官可以忘记自己当初是怎么学说话了吧?就找个小孩子观察一下吧。最好是自己的孩子。如果没有,就要抓紧了。
通过python能不能实现这个简单的功能呢?当然能,要不然python如何横行天下呀。
不过在写这个功能前,要了解两个函数:raw_input和print
> 这两个都是python的内建函数(built-in function)。关于python的内建函数,下面这个表格都列出来了。所谓内建函数,就是能够在python中直接调用,不需要做其它的操作。
Built-in Functions
* * *
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#abs-----divmod---input----open-----staticmethod)|abs() | divmod() | input()| open()| staticmethod()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#all-----enumerate----int--ord--str)|all() | enumerate() | int() | ord() | str()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#any-----eval-----isinstance---pow--sum)|any() | eval() | isinstance()| pow()| sum()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#basestring--execfile-----issubclass---print----super)|basestring() | execfile() | issubclass() | print() | super()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#bin-----file-----iter-----property-----tuple)|bin() | file() | iter()| property()| tuple()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#bool----filter---len--range----type)|bool() | filter() | len() | range() | type()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#bytearray---float----list-----raw_input----unichr)|bytearray() | float()| list() | raw_input()| unichr()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#callable----format---locals---reduce---unicode)|callable() | format() | locals() | reduce() | unicode()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#chr-----frozenset----long-----reload---vars)|chr() | frozenset() | long() | reload() | vars()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#classmethod-----getattr--map--repr-----xrange)|classmethod()| getattr()| map() | repr() | xrange()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#cmp-----globals--max--reversed-----zip)|cmp() | globals()| max()| reversed()| zip()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#compile--hasattr-----memoryview---round----import)|compile() |hasattr() | memoryview()| round() | **import**()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#complex--hash----min--set--apply)|complex() |hash() | min()| set() | apply()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#delattr--help----next-----setattr--buffer)|delattr() |help()| next()| setattr()| buffer()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#dict----hex---object---slice---coerce)|dict() | hex() |object() |slice() | coerce()|
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#dir-----id----oct--sorted---intern)|dir() | id() |oct() |sorted() |intern()|
这些内建函数,怎么才能知道哪个函数怎么用,是干什么用的呢?
不知道你是否还记得我在前面使用过的方法,这里再进行演示,这种方法是学习python的法宝。
~~~
>>> help(raw_input)
~~~
然后就出现:
~~~
Help on built-in function raw_input in module __builtin__:
raw_input(...)
raw_input([prompt]) -> string
Read a string from standard input. The trailing newline is stripped.
If the user hits EOF (Unix: Ctl-D, Windows: Ctl-Z+Return), raise EOFError.
On Unix, GNU readline is used if enabled. The prompt string, if given,
is printed without a trailing newline before reading.
~~~
从中是不是已经清晰地看到了`raw_input()`的使用方法了。
还有第二种方法,那就是到python的官方网站,查看内建函数的说明。[https://docs.python.org/2/library/functions.html](https://docs.python.org/2/library/functions.html)
其实,我上面那个表格,就是在这个网页中抄过来的。
例如,对`print()`说明如下:
~~~
print(*objects, sep=' ', end='\n', file=sys.stdout)
Print objects to the stream file, separated by sep and followed by end. sep, end and file, if present, must be given as keyword arguments.
All non-keyword arguments are converted to strings like str() does and written to the stream, separated by sep and followed by end. Both sep and end must be strings; they can also be None, which means to use the default values. If no objects are given, print() will just write end.
The file argument must be an object with a write(string) method; if it is not present or None, sys.stdout will be used. Output buffering is determined by file. Use file.flush() to ensure, for instance, immediate appearance on a screen.
~~~
分别在交互模式下,将这个两个函数操练一下。
~~~
>>> raw_input("input your name:")
input your name:python
'python'
~~~
输入名字之后,就返回了输入的内容。用一个变量可以获得这个返回值。
~~~
>>> name = raw_input("input your name:")
input your name:python
>>> name
'python'
>>> type(name)
<type 'str'>
~~~
而且,返回的结果是str类型。如果输入的是数字呢?
~~~
>>> age = raw_input("How old are you?")
How old are you?10
>>> age
'10'
>>> type(age)
<type 'str'>
~~~
返回的结果,仍然是str类型。
再试试`print()`,看前面对它的说明,是比较复杂的。没关系,我们从简单的开始。在交互模式下操作:
~~~
>>> print("hello, world")
hello, world
>>> a = "python"
>>> b = "good"
>>> print a
python
>>> print a,b
python good
~~~
比较简单吧。当然,这是没有搞太复杂了。
特别要提醒的是,`print()`默认是以`\n`结尾的,所以,会看到每个输出语句之后,输出内容后面自动带上了`\n`,于是就换行了。
有了以上两个准备,接下来就可以写一个能够“对话”的小程序了。
~~~
#!/usr/bin/env python
# coding=utf-8
name = raw_input("What is your name?")
age = raw_input("How old are you?")
print "Your name is:", name
print "You are " + age + " years old."
after_ten = int(age) + 10
print "You will be " + str(after_ten) + " years old after ten years."
~~~
对这段小程序中,有几点说明
前面演示了`print()`的使用,除了打印一个字符串之外,还可以打印字符串拼接结果。
~~~
print "You are " + age + " years old."
~~~
注意,那个变量`age`必须是字符串,如最后的那个语句中:
~~~
print "You will be " + str(after_ten) + " years old after ten years."
~~~
这句话里面,有一个类型转化,将原本是整数型`after_ten`转化为了str类型。否则,就包括,不信,你可以试试。
同样注意,在`after_ten = int(age) + 10`中,因为通过`raw_input`得到的是str类型,当age和10求和的时候,需要先用`int()`函数进行类型转化,才能和后面的整数10相加。
这个小程序,是有点综合的,基本上把已经学到的东西综合运用了一次。请看官调试一下,如果没有通过,仔细看报错信息,你能够从中获得修改方向的信息。
## [](https://github.com/qiwsir/StarterLearningPython/blob/master/107.md#原始字符串)原始字符串
所谓原始字符串,就是指字符串里面的每个字符都是原始含义,比如反斜杠,不会被看做转义符。如果在一般字符串中,比如
~~~
>>> print "I like \npython"
I like
python
~~~
这里的反斜杠就不是“反斜杠”的原始符号含义,而是和后面的n一起表示换行(转义了)。当然,这似乎没有什么太大影响,但有的时候,可能会出现问题,比如打印DOS路径(DOS,有没有搞错,现在还有人用吗?)
~~~
>>> dos = "c:\news"
>>> dos
'c:\news' #这里貌似没有什么问题
>>> print dos #当用print来打印这个字符串的时候,就出问题了。
c:
ews
~~~
如何避免?用前面讲过的转义符可以解决:
~~~
>>> dos = "c:\\news"
>>> print dos
c:\news
~~~
此外,还有一种方法,如:
~~~
>>> dos = r"c:\news"
>>> print dos
c:\news
>>> print r"c:\news\python"
c:\news\python
~~~
状如`r"c:\news"`,由r开头引起的字符串,就是原始字符串,在里面放任何字符都表示该字符的原始含义。
这种方法在做网站设置网站目录结构的时候非常有用。使用了原始字符串,就不需要转义了。