国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python實現設置windows桌面壁紙代碼分享

2020-02-23 00:26:10
字體:
來源:轉載
供稿:網友

每天換一個壁紙,每天好心情。

# -*- coding: UTF-8 -*- from __future__ import unicode_literalsimport Imageimport datetimeimport win32gui,win32con,win32apiimport refrom HttpWrapper import SendRequestStoreFolder = "c://dayImage"def setWallpaperFromBMP(imagepath):  k = win32api.RegOpenKeyEx(win32con.HKEY_CURRENT_USER,"Control Panel//Desktop",0,win32con.KEY_SET_VALUE)  win32api.RegSetValueEx(k, "WallpaperStyle", 0, win32con.REG_SZ, "2") #2拉伸適應桌面,0桌面居中  win32api.RegSetValueEx(k, "TileWallpaper", 0, win32con.REG_SZ, "0")  win32gui.SystemParametersInfo(win32con.SPI_SETDESKWALLPAPER,imagepath, 1+2)def setWallPaper(imagePath):  """  Given a path to an image, convert it to bmp and set it as wallpaper  """  bmpImage = Image.open(imagePath)  newPath = StoreFolder + '//mywallpaper.bmp'  bmpImage.save(newPath, "BMP")  setWallpaperFromBMP(newPath)def getPicture():  url = "http://photography.nationalgeographic.com/photography/photo-of-the-day/"  h = SendRequest(url)  if h.GetSource():    r = re.findall('<div class="download_link"><a href="(.*?)">Download',h.GetSource())    if r:      return SendRequest(r[0]).GetSource()    else:      print "解析圖片地址出錯,請檢查正則表達式是否正確"      return Nonedef setWallpaperOfToday():  img = getPicture()  if img:    path = StoreFolder + "http://%s.jpg" % datetime.date.today()    f = open(path,"wb")    f.write(img)    f.close()    setWallPaper(path)setWallpaperOfToday()print 'Wallpaper set ok!'


其中的httpwrapper是我寫的一個http訪問的封裝:

#!/usr/bin/env python # -*- coding: UTF-8 -*-#-------------------------------------------------------------------------------# Name: 對http訪問的封裝## Author: qianlifeng## Created: 10-02-2012#-------------------------------------------------------------------------------import base64import urllibimport urllib2import timeimport reimport sysclass SendRequest: """ 網頁請求增強類 SendRequest('http://xxx.com',data=dict, type='POST', auth='base',user='xxx', password='xxx') """ def __init__(self, url, data=None, method='GET', auth=None, user=None, password=None, cookie = None, **header):  """  url: 請求的url,不能為空  date: 需要post的內容,必須是字典  method: Get 或者 Post,默認為Get  auth: 'base' 或者 'cookie'  user: 用于base認證的用戶名  password: 用于base認證的密碼  cookie: 請求附帶的cookie,一般用于登錄后的認證  其他頭信息:  e.g. referer='www.sina.com.cn'  """  self.url = url  self.data = data  self.method = method  self.auth = auth  self.user = user  self.password = password  self.cookie = cookie  if 'referer' in header:    self.referer = header[referer]  else:    self.referer = None  if 'user-agent' in header:    self.user_agent = header[user-agent]  else:## self.user_agent = 'Mozilla/5.0 (Windows NT 5.1; rv:8.0) Gecko/20100101 Firefox/8.0'    self.user_agent = 'Mozilla/5.0 (iPhone; U; CPU iPhone OS 3_0 like Mac OS X; en-us) AppleWebKit/528.18 (KHTML, like Gecko) Version/4.0 Mobile/7A341 Safari/528.16'  self.__SetupRequest()  self.__SendRequest() def __SetupRequest(self):  if self.url is None or self.url == '':    raise 'url 不能為空!'  #訪問方式設置  if self.method.lower() == 'post':    self.Req = urllib2.Request(self.url, urllib.urlencode(self.data))  elif self.method.lower() == 'get':    if self.data == None:      self.Req = urllib2.Request(self.url)    else:      self.Req = urllib2.Request(self.url + '?' + urllib.urlencode(self.data))  #設置認證信息  if self.auth == 'base':    if self.user == None or self.password == None:      raise 'The user or password was not given!'    else:      auth_info = base64.encodestring(self.user + ':' + self.password).replace('/n','')      auth_info = 'Basic ' + auth_info      self.Req.add_header("Authorization", auth_info)  elif self.auth == 'cookie':    if self.cookie == None:      raise 'The cookie was not given!'    else:      self.Req.add_header("Cookie", self.cookie)  if self.referer:    self.Req.add_header('referer', self.referer)  if self.user_agent:    self.Req.add_header('user-agent', self.user_agent) def __SendRequest(self):  try:   self.Res = urllib2.urlopen(self.Req)   self.source = self.Res.read()   self.code = self.Res.getcode()   self.head_dict = self.Res.info().dict   self.Res.close()  except:   print "Error: HttpWrapper=>_SendRequest ", sys.exc_info()[1] def GetResponseCode(self):  """  得到服務器返回的狀態碼(200表示成功,404網頁不存在)  """  return self.code def GetSource(self):  """  得到網頁源代碼,需要解碼后在使用  """  if "source" in dir(self):    return self.source  return u'' def GetHeaderInfo(self):  """  u'得到響應頭信息'  """  return self.head_dict def GetCookie(self):  """  得到服務器返回的Cookie,一般用于登錄后續操作  """  if 'set-cookie' in self.head_dict:   return self.head_dict['set-cookie']  else:   return None def GetContentType(self):  """  得到返回類型  """  if 'content-type' in self.head_dict:   return self.head_dict['content-type']  else:   return None def GetCharset(self):  """  嘗試得到網頁的編碼  如果得不到返回None  """  contentType = self.GetContentType()  if contentType is not None:    index = contentType.find("charset")    if index > 0:      return contentType[index+8:]  return None def GetExpiresTime(self):  """  得到網頁過期時間  """  if 'expires' in self.head_dict:   return self.head_dict['expires']  else:   return None def GetServerName(self):  """  得到服務器名字  """  if 'server' in self.head_dict:   return self.head_dict['server']  else:   return None__all__ = [SendRequest,]if __name__ == '__main__':  b = SendRequest("http://www.baidu.com")  print b.GetSource()            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 丹凤县| 台前县| 赫章县| 宁南县| 聊城市| 灵台县| 广昌县| 安陆市| 巴青县| 五大连池市| 泰顺县| 达尔| 新昌县| 射洪县| 呈贡县| 松潘县| 施秉县| 安康市| 阆中市| 榕江县| 确山县| 泰顺县| 揭阳市| 郎溪县| 靖边县| 房产| 绥宁县| 土默特右旗| 高邑县| 耒阳市| 环江| 鄂托克旗| 兴文县| 湛江市| 清镇市| 静安区| 黎川县| 溆浦县| 英山县| 岑巩县| 治多县|