1. 程式人生 > >sys.path.insert()&sys.path.append()

sys.path.insert()&sys.path.append()

itl 語句 性能 new size 大小 sep 什麽 def

註:sys.path模塊是動態的修改系統路徑

模塊要處於Python搜索路徑中的目錄裏才能被導入,但我們不喜歡維護一個永久性的大目錄,因為其他所有的Python腳本和應用程序導入模塊的時候性能都會被拖累。本節代碼動態地在該路徑中添加了一個"目錄",當然前提是此目錄存在而且此前不在sys.path中。

sys.path是個列表,所以在末尾添加目錄是很容易的,用sys.path.append就行了。當這個append執行完之後,新目錄即時起效,以後的每次import操作都可能會檢查這個目錄。如同解決方案所示,可以選擇用sys.path.insert(0,…,這樣新添加的目錄會優先於其他目錄被import檢查。

即使sys.path中存在重復,或者一個不存在的目錄被不小心添加進來,也沒什麽大不了,Python的import語句非常聰明,它會自己應付這類問題。但是,如果每次import時都發生這種錯誤(比如,重復的不成功搜索,操作系統提示的需要進一步處理的錯誤),我們會被迫付出一點小小的性能代價。為了避免這種無謂的開銷,本節代碼在向sys.path添加內容時非常謹慎,絕不加入不存在的目錄或者重復的目錄。程序向sys.path添加的目錄只會在此程序的生命周期之內有效,其他所有的對sys.path的動態操作也是如此。

  1. def AddSysPath(new_path):
  2. """ AddSysPath(new_path):給Python的sys.path增加一個"目錄"
  3. 如果此目錄不存在或者已經在sys.path中了,則不操作
  4. 返回1表示成功,-1表示new_path不存在,0表示已經在sys.path中了
  5. already on sys.path.
  6. """
  7. import sys, os
  8. # 避免加入一個不存在的目錄
  9. if not os.path.exists(new_path): return -1
  10. # 將路徑標準化。 Windows是大小寫不敏感的,所以若確定在
  11. # Windows下,將其轉成小寫
  12. new_path
    = os.path.abspath(new_path)
  13. if sys.platform == ‘win32‘:
  14. new_pathnew_path = new_path.lower( )
  15. # 檢查當前所有的路徑
  16. for x in sys.path:
  17. x = os.path.abspath(x)
  18. if sys.platform == ‘win32‘:
  19. xx = x.lower( )
  20. if new_path in (x, x + os.sep):
  21. return 0
  22. sys.path.append(new_path)
  23. # 如果想讓new_path在sys.path處於最前
  24. # 使用:sys.path.insert(0, new_path)
  25. return 1
  26. if _ _name_ _ == ‘_ _main_ _‘:
  27. # 測試,顯示用法
  28. import sys
  29. print ‘Before:‘
  30. for x in sys.path: print x
  31. if sys.platform == ‘win32‘:
  32. print AddSysPath(‘c:\\Temp‘)
  33. print AddSysPath(‘c:\\temp‘)
  34. else:
  35. print AddSysPath(‘/usr/lib/my_modules‘)
  36. print ‘After:‘
  37. for x in sys.path: print x

sys.path.insert()&sys.path.append()