Python基礎(chǔ)中os和數(shù)據(jù)結(jié)構(gòu)是怎么樣的,很多新手對此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
站在用戶的角度思考問題,與客戶深入溝通,找到柳江網(wǎng)站設(shè)計(jì)與柳江網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:做網(wǎng)站、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名注冊、虛擬空間、企業(yè)郵箱。業(yè)務(wù)覆蓋柳江地區(qū)。今天總結(jié)了下Python的基礎(chǔ),發(fā)現(xiàn)還是有很多基礎(chǔ)需要鞏固,直接把學(xué)習(xí)的內(nèi)容放上來。
>>> import os 得到當(dāng)前的所在的路徑 >>> os.getcwd() '/root/test' 列出當(dāng)前路徑所在的文件夾下的文件 >>> os.listdir(os.getcwd()) ['a.py', 'redis_test.sql', 'cmdb_server.txt', 'a.sql', 'test.py', 'redis_test.txt', 'paramiko.pyc', 'cmdb_server.txt.bak', 'paramiko.py', 'requirements_add.txt', 'test.txt', 'opsmanage.tar.gz', 'test.sql'] 返回當(dāng)前的絕對路徑 >>> os.path.abspath('.') '/root/test' 得到當(dāng)前路徑上一次的絕對路徑 >>> os.path.abspath('..') '/root' 把路徑分解為路徑和文件名 >>> os.path.split('/root/test/test.py') ('/root/test', 'test.py') >>> os.path.split('.') ('', '.') 將路徑進(jìn)行合并 >>> os.path.join('/root/test','test.py') '/root/test/test.py' 返回指定path的文件夾部分 >>> os.path.dirname('/root') '/' 返回當(dāng)前path的文件夾 >>> os.path.dirname(os.getcwd()) '/root' 得到當(dāng)前的路徑,和上面的可以互為印證 >>> os.getcwd() '/root/test' 返回path中的文件名 >>> os.path.basename('/root/test/test.py') 'test.py' 返回path中的子文件夾 >>> os.path.basename('/root/test') 'test' >>> os.path.basename('/root/test/') '' 得到文件或文件夾的最后修改時(shí)間 >>> os.path.getmtime('/root/test/test.py') 1521193690.4832795 得到文件或文件夾的大小,注意文件夾的部分得到的可能不是真實(shí)的大小,不是du -sh 類似的結(jié)果 >>> os.path.getsize('/root/test/test.py') 29 查看文件或者文件夾是否存在 >>> os.path.exists('/root/test/test.py') True >>> os.path.exists('/root/test/test.py22') False
一些路徑在不同操作平臺(tái)的表示 >>> os.sep '/' >>> os.extsep '.' >>> os.linesep '\n' >>> os.pathsep ':'
得到目錄下的文件 >>> os.listdir(os.getcwd()) ['dict.py', 'sqlplan.py', 'deploy.pyc', 'task_manage.py', 'cron.py', 'mysql_manage.py', 'system_manage.pyc', 'cmdb.pyc', 'deploy.py', 'ansible.pyc', 'index.py', 'tuning.ini', 'cron.pyc', 'backup.pyc', 'mysql_manage.pyc', 'users.py', 'celeryHandle.py', 'assets.pyc', '__init__.pyc', 'ansible.py', '__init__.py', 'task_manage.pyc', 'cmdb.py', 'users.pyc', 'assets.py', 'system_manage.py', 'index.pyc', 'dict.pyc', 'backup.py'] 對當(dāng)前目錄下的文件存入列表 >>> lists=os.listdir(os.getcwd()) 對列表進(jìn)行排序 >>> lists.sort() 得到列表 >>> print(lists) ['__init__.py', '__init__.pyc', 'ansible.py', 'ansible.pyc', 'assets.py', 'assets.pyc', 'backup.py', 'backup.pyc', 'celeryHandle.py', 'cmdb.py', 'cmdb.pyc', 'cron.py', 'cron.pyc', 'deploy.py', 'deploy.pyc', 'dict.py', 'dict.pyc', 'index.py', 'index.pyc', 'mysql_manage.py', 'mysql_manage.pyc', 'sqlplan.py', 'system_manage.py', 'system_manage.pyc', 'task_manage.py', 'task_manage.pyc', 'tuning.ini', 'users.py', 'users.pyc'] sort按key的關(guān)鍵字進(jìn)行升序排序,lambda的入?yún)n為lists列表的元素,獲取文件的最后修改時(shí)間,所以最終以文件時(shí)間從小到大排序 最后對lists元素,按文件修改時(shí)間大小從小到大排序 >>> lists.sort(key=lambda fn:os.path.getmtime(os.getcwd()+'/'+fn) ) >>> print(lists) ['__init__.py', 'deploy.py', 'cron.py', 'ansible.py', '__init__.pyc', 'cron.pyc', 'deploy.pyc', 'ansible.pyc', 'assets.py', 'assets.pyc', 'celeryHandle.py', 'sqlplan.py', 'tuning.ini', 'dict.py', 'dict.pyc', 'index.py', 'index.pyc', 'task_manage.py', 'task_manage.pyc', 'users.py', 'users.pyc', 'system_manage.py', 'system_manage.pyc', 'cmdb.py', 'cmdb.pyc', 'backup.py', 'backup.pyc', 'mysql_manage.py', 'mysql_manage.pyc'] 得到文件的擴(kuò)展名,如果輸入是文件夾,返回為空 >>> os.path.splitext(os.getcwd()) ('/root/OpsManage-master/OpsManage/views', '') >>> os.path.splitext('/root/OpsManage-master/OpsManage/views/task_manage.pyc') ('/root/OpsManage-master/OpsManage/views/task_manage', '.pyc') 列出當(dāng)前目錄下所有的.py文件 >>> [x for x in os.listdir('.') if os.path.isfile(x) and os.path.splitext(x)[1]=='.py'] ['dict.py', 'sqlplan.py', 'task_manage.py', 'cron.py', 'mysql_manage.py', 'deploy.py', 'index.py', 'users.py', 'celeryHandle.py', 'ansible.py', '__init__.py', 'cmdb.py', 'assets.py', 'system_manage.py', 'backup.py']
數(shù)據(jù)結(jié)構(gòu)操作
列表操作 >>> header=[1,2,3] >>> dat=[3,2,1] 列表轉(zhuǎn)換為字典 >>> dict(zip(header,dat)) {1: 3, 2: 2, 3: 1} 運(yùn)行操作系統(tǒng)命令,使用popen >>> cmd='hostname' >>> os.popen(cmd)>>> os.popen(cmd).read() 'dev01\n' 運(yùn)行操作系統(tǒng)命令,使用commands,這個(gè)返回更豐富一些 >>> import commands >>> commands.getstatusoutput('hostname') (0, 'dev01') 列表的追加 >>> ll=['a','b','c','d'] >>> ll.append('jeanron100') >>> print(ll) ['a', 'b', 'c', 'd', 'jeanron100'] 判斷列表元素是否存在 >>> print ll.count('jeanron100') 1 >>> print ll.count('jeanron1000') 0 列表的組合,如果是兩個(gè)列表,效果就更清晰了 >>> ll.extend(['jeanron','jianrong']) >>> print(ll) ['a', 'b', 'c', 'd', 'jeanron100', 'jeanron', 'jianrong'] 刪除指定元素 >>> ll.remove('jeanron') >>> print(ll) ['a', 'b', 'c', 'd', 'jeanron100', 'jianrong'] 反向輸出列表元素 >>> ll.reverse() >>> print(ll) ['jianrong', 'jeanron100', 'd', 'c', 'b', 'a'] 列表排序 >>> ll.sort() >>> print(ll) ['a', 'b', 'c', 'd', 'jeanron100', 'jianrong']
字典操作 >>> info={'name':'jeanron','age':33,'gender':'male'} >>> print info.get('name') jeanron 輸出字典的鍵值 >>> print info.keys() ['gender', 'age', 'name'] >>> print info.items() [('gender', 'male'), ('age', 33), ('name', 'jeanron')] 以列表返回字典中的所有值 >>> print info.values() ['male', 33, 'jeanron']
集合操作 >>> info={'my','name','is','jeanron'} >>> print info set(['jeanron', 'is', 'my', 'name']) >>> test_info={'this','is','a','test'} 集合交集 >>> print info&test_info set(['is']) 合集 >>> print info.union(test_info) set(['a', 'name', 'this', 'is', 'jeanron', 'test', 'my']) 并集 >>> print info|test_info set(['a', 'name', 'this', 'is', 'jeanron', 'test', 'my'])
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。