首页 > 代码库 > Python 学习之urllib模块---用于发送网络请求,获取数据(2)

Python 学习之urllib模块---用于发送网络请求,获取数据(2)

      接着上一次的内容。

      先说明一下关于split()方法:它通过指定分隔符对字符串进行切片,如果参数num 有指定值,则仅分隔 num 个子字符串(把一个字符串分割成很多字符串组成的list列表)

                              语法:str.split(str="", num=string.count(str)).

                              参数:str 分隔符,默认为空格。num 分割次数

                             返回值:返回分割后的字符串列表

                             例如:你需要将一个英语句子中的每一个单词拿出来单独处理,就可以将其进行分割。

                                      如:a=‘ I am a new student‘

                                           a.split() 

                                           split会将字符串按照空格进行分割,分割后得到的都是新的字符串,最终返回字符串组成的list

                                           结果[‘I‘,‘am‘,‘a‘,‘new‘,‘student‘]

                                           其实split()方法和excel里的分隔符很像。

                              其对应的是连接list的字符串的方法join(),是将list中的所有字符串连接成为一个字符串

                              如:s=‘,‘   lis=[‘I‘,‘am‘,‘a‘,‘new‘,‘student‘]   result=s.jion(lis)     print result         得到结果为 ‘I,am,a,new,student‘

                                按,连接list          

                             list可以用for...in遍历lis中的元素。   for i in rang(1,10)这里的rang(1,10)就是一个list  [1,2,3,4,5,6,7,8,9] 

                             I=rang(1,10)=[1,2,3,4,5,6,7,8,9],  for i in I :和 for i  in rang(1,10):效果是一样的。

                             说明一下如何操作list列表

                             1】访问list中的元素   如上述print lis[0]就会输出‘I‘

                             2】修改list中的元素   如修改上述lis,lis[4]=‘teacher‘,输出lis时最后一个元素被改成‘teacher‘

                             3】list中添加元素    用append方法  如lis.append(2016)

                             4】删除list元素       用del方法,如del[4]

      啊,说了这么多,其实感觉是不是米有啥用,其实这些都是基本知识,今天自己在复习一遍,因为抓取网络上的内容经常是要操作list列表滴。看了这些内容,今天就可以继续学习抓取省/直辖市的编号。

      昨天学习的就是如何获取一个网络资源的信息,也就是和文件操作类似,就是打开 ,然后读取,解码,分割成为list列表这几个步骤。可以直接用这个代码

      b=urllib.request.urlopen(‘http://m.weather.com.cn/data5/city.xml‘).read().decode().spilt(‘,‘)

      这样就可以得到一个b的列表啦,也就是上述截图print打印出来的内容。分析一下,我们要得到数据01,02,就必须操作这个b列表啦

      下面就可以操作这个b列表了,试试

      print  (b[0]) 看看,是不是打印出‘01|北京‘ ? 继续分析,此时b[0]也是一个字符串,将其按照|分割,就可以得出01啦,所以操作如下,应该是b[0].spilt(‘|‘)了,分割出来的数据应该是[01,‘北京’]了,此时再取值:b[0].split(‘|‘)[0]?思路是这样,看看是不是?

      一个是这样操作,那多个相同的就得循环啦,所以就得用到上述用的for i  in list

     for  i  in   b:                #i=b[0],b[1],b[2]。。。。。。

          code=i.split(‘|‘)[0]

          web=‘http://m.weather.com.cn/data5/city%s‘

          web1=web %code

          print (web1) 

      看看是不是能打印出来第二个接口的数据了?  当然如果觉得太多,可以只打出2~3个省的看看。for i  in  b[:2]

      额,有点晚了,明天接着来2016年9月1号

Python 学习之urllib模块---用于发送网络请求,获取数据(2)