WinZip解压缩之操作教学

时间:2023-06-29 08:19:22 其他范文 收藏本文 下载本文

WinZip解压缩之操作教学(精选14篇)由网友“Diss”投稿提供,以下是小编为大家准备的WinZip解压缩之操作教学,希望对大家有帮助。

WinZip解压缩之操作教学

篇1:WinZip解压缩之操作教学

1.在档案总管中连击滑鼠左键二下,开启abc123.zip之压缩档,

WinZip解压缩之操作教学

下载地址:WinZip

2.WinZip程式⒆绦校K得到如下面,cxExtract按oM行解嚎s工作。2.WinZip程式将自动执行,并得到如下画面,点选Extract按钮进行解压缩工作。

3.你可以在Extract to中直接入要存放解横n案的目,也可以闹虚g的目^中cx,O定好後按Extracto,即_始M行解嚎s工作,

3.你可以在Extract to中直接输入要存放解压后档案的目录,也可以从中间的目录区中点选,设定好后按Extract钮,即开始进行解压缩工作。

4.窗右下角的B簦由t糇Gr就是已完成工作。4.当视窗右下角的状态灯,由红灯变绿灯时就是已经完成工作。

5.如下已利的n案解嚎s在C:\Temp\中。5.如下已经顺利的将档案解压缩在C:\Temp\中。

篇2:IZarc:免费的替代winrar/Winzip的解压缩软件免费方案

IZarc是又一款免费的解压缩软件,它可以解压和压缩的文档格式非常多,包括7-ZIP, A, ACE, ARC, ARJ, B64, BH, BIN,BZ2, BZA, C2D, CAB, CDI, CPIO, DEB, ENC, GCA, GZ, GZA, HA, IMG, ISO, JAR, LHA, LIB, LZH, MDF, MBF, MIM, NRG,PAK, PDI, PK3, RAR, RPM, TAR, TAZ, TBZ, TGZ, TZ, UUE, WAR, XXE, YZ1, Z, ZIP, ZOO,和RJNo1.com介绍的替代winrar和winzip的软件7zip功能都大同小异,对于平常的应用足以应付。并且它还是完全免费,中文版的哦。

IZarc有什么特色?

它可以对压缩软件进行加密!你肯定要说别的软件也行啊?但是和其他软件比较起来IZarc压缩软件的加密非常强!有了它,你可以使用aes-128位密钥加密,也可以使用强度更高的192位密钥和256位密钥,

或者你也可以使用较早的pk zip加密方式。

它可以修复受损的zip压缩文件,并且可以直接把一种压缩格式的压缩文件转换成另一种格式,省去了你解压后在压缩的时间。

你也可以使用IZarc把BIN格式和NRG格式的cd文档转换成iso格式的cd文档,,如果你要使用文件的电脑没有解压缩软件,那么你还可以使用这款软件制作自解压的压缩文档哦。

IZarc也支持右键菜单操作解压/压缩文件,所以你不用担心习惯问题。

这款软件还有皮肤功能,如果你不喜欢它默认的样式,你可以换成其他风格,它自带的就有十几种,可以说是一个十分美观的解压缩软件了。

关 键 字:IZArc

篇3:linux常用命令之压缩、解压缩

命令名称: gzip 、gunzip

功能:.gz 后缀,只能压缩文件,不能压缩目录,不保留源文件

<?www.2cto.com/kf/ware/vc/“ target=”_blank“ class=”keylink“>vcD4KPHA+w/zB7sP7s8ajunRhcjwvcD4KPHA+uabE3KO6tPKw/DwvcD4KPHA+PGltZyBzcmM9”www.2cto.com/uploadfile/Collfiles/1202/2014192457234.png“ alt=”\“>

命令名称:zip、unzip

功能:保留源文件 -r 压缩目录

命令名称:bzip2

功能: -k保留源文件,是gzip升级,压缩比更高

篇4:WinRAR解压缩CRC出错之解决方法

WinRAR可以说是现在最风光的压缩软件了,风头逐渐盖过了老牌的WinZip!超高的压缩比,简单易用的界面,强大的功能……不过不知道大家有没有碰到过这样的情况:辛辛苦苦从网上下载了数百兆的RAR压缩包文件,正解压时突然弹出一个让你心惊肉跳对话框!告诉你出错了……

判断出错原因

出错信息为“CRC失败于加密文件(口令错误?)”(RAR压缩包设了密码,但密码输入错误或是密码输入正确但循环冗余校验码(CRC)出错!只不过因为此RAR压缩包加了密码的缘故,所以WRAR才猜测说可能是“口令错误”)

区分上面两种错误的方法:如果密码输入错误的话是无法解压出任何文件的!但如果压缩包内有多个文件,且有一部分文件解压缩出来了,那么应该是RAR压缩包循环冗余校验码(CRC)出错而不是密码输入错误,

循环冗余校验码(CRC)出错,这是最常见的情况,这也是本文讨论的重点!和上面的几种解压缩出错不同,这种情况是和RAR压缩包损坏有关的。

原因有几种:

(1)网络传输状况不好(如断线过多,开的线程过多,服务器人太多导致不能连接太多等)导致下载下来的文件损坏?br/>

(2)站点提供的的RAR压缩包本来就是损坏的(这就没办法了,除非此压缩包中含有回复记录)。

(3)所使用的下载工具不够完善,比如有的下载工具多开了几个线程后,下载的收尾工作很慢,有些时候下载到99%时数据就不再传输了,一定要人工操作才能结束(先停止下载接着再开始)。笔者就碰到过好几次这样的情况。结果是文件下载下来以后解压缩到快结束时CRC出错。

应急解决

1.利用恢复记录

想要修复CRC是有条件的,必须是此RAR压缩包中有恢复记录,而此恢复记录是RAR压缩包被压缩时的可选项。

而WinRAR压缩时默认是不放置恢复记录的,如果提供的是这样的RAR压缩包,那么用户自己想要修复CRC错误是不可能的。

2.釜底抽薪

如果RAR压缩包中的文件是那种即使文件有缺失仍能正常或较为正常地使用的(其实大多数的文件对部分数据损坏都不是非常敏感的),那便可以使出我们的终极杀招:釜底抽薪法?br/>

其原理就是让RAR压缩包内损坏的文件解压缩出来,不理会WinRAR的警告,能解压多少就解压多少,

解压缩软件还是用WinRAR,不过要做小小的设置。

在右键点击解压缩文件后跳出的窗口里,把“保留被损坏的文件”复选框选中,点击确定开始解压缩。不要理会解压缩出错的信息,解压缩结束之后你会发现损坏的文件被解压出来了。经过这样解压出来的损坏文件能正常使用的几率还是非常高的。

点击阅读更多学院相关文章>>

分享到做好保险工作

1.做好恢复记录

原始RAR压缩包在压缩时,如果选择放置恢复记录,这样用户下载后即使CRC出错也有自己修复的机会?br/>

2.采取分卷压缩

采取分卷压缩的方法便可较大地减少因为出现不可恢复的错误带来的损失。

3.老文件也加恢复记录

有人也许会问,新压缩的RAR压缩包可以加入恢复记录,那么已经压缩过的RAR包有没有办法也加上恢复记录呢?给已经压缩好的RAR压缩包加上恢复纪录是有办法的。

只需要打开压缩包,在“命令”菜单中选择“保护档案文件”即可。

小常识:

其实RAR压缩包出错的解决方法主要是以预防为主!如果没有预防,等到真正出了问题,技术上也是没办法完美解决的!像循环冗余校验码(CRC)出错这种情况,如果RAR压缩包不包含恢复记录的话,用户自己想要修复CRC是不可能的!本文的主要目的是想告诉大家一些出错的原因以及讨论一些从根本上预防出错和把损失减少到最小的办法而已?br/>

上一页 1 2

点击阅读更多学院相关文章>>

分享到

篇5:执业医师考试之操作考试

执业医师考试之操作考试

今天去卫生局参加了执业医师考试的操作考试,是我第一次报名参加执业考试,执业助理考试的时候也在这栋大楼奋战了三年,对考试的程序很熟悉,卫生局那几个工作人员的面孔也很熟悉,每次从报名到考试引导都是这几个人,考场的监考官也面熟,还是我考执业助理医师的那两个监考官,但是今天考完出来后感觉从来没有这么糟糕过,考试完了之后大家站在门口相互询问考了哪些题目,我就觉得为什么别人的题目就那么容易,我抽的题目(125号题组)就那么难呢?今天居然还是真人模特,我还一直以为像过去一样是人体模型呢?今天下午考试只有22人,还有一个人缺考,记得以前考执业助理医师的时候卫生局10楼的会议室都坐满了,起码也有五六十人吧,原来事隔两年没有参加考试了,很多东西都已经改变了。在去考试的路上我就有一种第一次参加执业助理医师考试的那种心态,反正也是没有看书,就抱着试试看的心态去了,但是没有想到这次运气这么差,抽的题目都不是自己熟悉的。面对监考官的`询问和自己的表现我当时就知道这次没有任何希望啦,根本就不用准备笔试的考试了。(”你在哪个医院上班?你在哪个学校毕业?你在哪个医院实习的?“”我没有在医院上班,我在服务站上班,我长沙医学院毕业,我在县人民医院实习的,为了怕和准考证上的工作单位不一致,我谎称自己在服务站上班,“监考老师连续问了我这么多的问题,言下之意就是这么简单的题目都不会做。)但是今年我却没有任何的紧张感,心态挺平和的,往年考试每次走进这间房子或者还在侯考区的时候,我就心跳加速.也许是自己对自己太清楚了,就算操作能够通过,我的笔试也过不了,自己有几斤几两还是知道的,再来奋战三年吧!今年的执考之路到此结束了,明年再见.第一站一、病史采集:1、男性,?岁,发热颈部淋巴结肿大半月来门诊就诊。二、病例分析:1、.腹痛、停止排便排气2天.第二站:一、体格检查:1、胸膜摩擦音(问题:最常见于哪里?)2、肝脏触诊(问题:舟状腹最常见于哪些疾病?)3、脊柱检查二、基本操作:1、.结肠癌手术皮肤消毒.(问题:如果消毒留下空白区怎么办?消毒范围?)第三站:人机对话(辅助检查)1、心电图2、X线3、超声(?印象中好像没有B超题,未必是我漏答了?)4、CT 5、医德医风

篇6:python学习之操作mysql

刚开始学python,所以很多代码都需要在ipython里尝试一下,今天记录的是最基本的操作mysql数据库。

写数据库连接操作的时候,仿佛回到了当年在前两家公司写asp.net的感觉。

1.首先在mysql数据库里新建个数据库

create database db_02 default charset utf8;

create table user (id int auto_increment primary key,username char(20),email char(20));

2.开始写python代码

import MySQLdb

conn = MySQLdb.connect(user=’root’,host=’localhost’,passwd=”)

conn.select_db(‘db_02′)

cursor =conn.cursor

sql = ‘insert into user(name,email) values(“andy”,”andy@163.com”)’

cursor.execute(sql)

————————————————

cursor.execute(‘insert into user(name,email) values(“andy”,”andy@163.com”)’)

查看:

In [14]: sql=’select * from user’

In [15]: cur.execute(sql)

Out[15]: 2L

In [16]: cur.fetchone()

Out[16]: (1L, ‘andy’, ‘andy@163.com’, None)

In [17]: cur.fetchone()

Out[17]: (2L, ‘andy’, ‘andy@163.com’, None)

In [19]: cur.execute(sql)

Out[19]: 2L

In [20]: cur.fetchall()

Out[20]: ((1L, ‘andy’, ‘andy@163.com’, None), (2L, ‘andy’, ‘andy@163.com’, None))

最后是

cursor.close()

conn.close()

写到这里认为万事大吉喽,去mysql里一看发现数据没进来,找了原因才知道这是与表的类型有关,

mysql>show create table user;

+——-+————————————————————————————–

| Table | Create Table

+——-+————————————————————————————–

| user | CREATE TABLE `user` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`name` char(20) NOT NULL,

`email` char(20) NOT NULL,

`password` char(200) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8 |

+——-+————————————————————————————–

因为用的是InnoDB,不是MyISAM, MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持。MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但是不提供事务支持,而InnoDB提供事务支持已经外部键等高级数据库功能。MyISAM的读性能是比Innodb强不少的.

所以只要加上一句conn.commit(),数据库里就可以看到记录了

原文来自:www.iwangzheng.com/?p=257

篇7:教学课件操作说明

多媒体课件集文字、符号、图形、图像、动画、声音、视频于一体,交互性强,信息量大,能多路刺激学生的视觉、听觉等器官,使课堂教育更加直观、形象、生动,提高了学生学习的主动性与积极性,减轻了学习负担,有力地促进了课堂教育的灵活与高效。那么是如何操作的呢?

一、课件运行环境:

硬件要求:电脑配置应当在奔腾Ⅲ及奔腾Ⅲ以上CPU、256MB内存、20MB硬盘空间。

软件要求:兼容Windows98//XP,该课件在Flash8.0版本测试通过,flash8.0以下版本不能完全显示,如果无法播放,可以先运行本光盘下的“SAFlashPlayer.exe”,然后打开 “我心中的客家.swf”即可运行。

二、使用环境:

该课件是以“学生为主体、教师为主导”的思想设计的,所以该课件中要求学生自己动手操作的部分较多,所以最好在多媒体机房使用这个课件,力争每个学生有一台电脑,教师机能够向每台学生机分发该课件、并能够向学生广播教师机的屏幕。

三、课件基本操作

课件内容播放以鼠标单击相应按钮完成。共有两种播放模式:

一种是顺序式播放,如单击 按钮可以观看下一画面,单击 按钮就可以返回前一画面。同一画面里的动画就是可单击相应的按钮,如 按钮可以播放; 按钮可以重来; 按钮可以暂停; 按钮关闭课件。

另一种是目录式播放,单击 就可以打开相应的目录树: 共七个环节。点击其中的按钮就可以进入相应的环节进行教学。

四、教学过程设计参考

(一)话题导入,创设情境

(打开课件,欣赏课件片头)

1.师:同学们,我们赣县是“客家的摇篮”,今天我们的活动就围绕着“客家”这个话题展开。课前,大家都搜集了大量有关客家的资料,下面我们来交流一下,你都搜集到了哪些资料?

2.引导学生回答。(说说对客家的印象,资料是怎么得来的?)(播放课件,单击 )

(这一过程引发学生要将美丽客家的景物等留到电脑里的愿望)

(二)引导新授,创作作品

A、猜:

1.师:看来,大家对客家都有一定的了解,还会利用先进的手段来获取这些信息,真不错!接下来的问题一定难不倒你们,让我们一起来“猜猜看”……

2.(播放课件,单击 ),逐次点击有关客家的图片,最后出示一张,让学生猜 “这是什么地方?”

3.生:“赣县客家文化城”。

4.师:看完了这些图片,此时此刻你们有什么感受?

5.生:客家历史悠久、风光迷人……

B、写:

1.师:相信其他同学也有这样的感受,那么就把你们心中最想说的话,用计算机里的记事本写下来吧!每人写一句。

2.学生动手操作,打开记事本,写下心中赞美的话。

3.指名说说你写得是什么?(我爱客家……)

C、赏:

1.师:美丽的客家、现代的客家、充满希望的客家,如诗如画的风景带给人无尽的睱想……那么你们准备怎样向国内、外的游客介绍我们客家的文化呢?老师这儿有两幅作品,看后也许会对你有所启发。(播放课件,单击 )

2.播放宣传片(单击 )。

3.展示电子作品(单击 )。

D、做:

1.师:想不想拥有自己的宣传作品呢?你打算用什么来做?

2.经过组内讨论后,有的同学说我们想用PowerPoint做;我想用Word来做……

3.师:好,下面就进入“做一做”环节,开始创作你们富有个性的作品吧!可以独立完成,也可以几人合作。(播放课件,单击 )

5.学生开始创作,教师巡回指导。

E、评:

选择部分学生作品通过多媒体教室的转播功能评一评好在什么地方,为什么?不足的地为是什么?先自评,然后其他同学评价与老师评价相结合方式进行。(播放课件,单击 )

F、唱:

1.小结:同学们,在短短的一节课里,我们无法把心中对客家的热爱之情全部展现出来,但我相信你们都有所收获。

2、师:老师也和你们一样,有收获,特意用flash做了一首歌,想不想唱?(播放课件,单击 后,单击 开始学唱《新客家谣》)

3、课堂在歌声中结束……

篇8:《操作键盘》教学设计

《操作键盘》教学设计

一、教材分析:

《操作键盘》是江苏省小学信息技术教材第6课第一课时的教学内容,本课是在学生学完“认识键盘”的基础上,对“操作键盘”的进一步认识。编者将这一课时内容分解为“正确的姿势”、“基准键”、“手指分工”三个部分,用简洁、易懂的方式为我们讲述了键盘操作的基本要领。这些知识的掌握是学好后续“输入汉字”的基础。本课在这一单元起着承上启下的作用。基于对教材的理解和分析,结合学生的实际,我从知识与技能、过程与方法,情感态度与价值观三方面制定了本课的教学目标。

二、教学目标:

知识目标:

1.掌握正确的打字姿势。

2.掌握正确的指法。

能力目标:

培养学生解决实际问题的能力,能在学习中举一反三,提高自学能力。

情感目标:

培养学生交流、协作精神,激活学生的自学习兴趣,提高学生的信息素养。

教学重、难点:

1.掌握正确的打字姿势。

2.掌握正确的指法。

三、教学准备:

1.我准备:每人寻宝秘笈一张(自编教材),学生自主学习,并完成“助学单”。

2.打字游戏。

四、教法阐述:

本课的教学设计以“多维交互我课堂教学模式”为指导,通过创设符合小学生认知规律的学习氛围,引导学生带着兴趣、动力和激情快速进入课堂,走上自主学习、主动学习的轨道。这样的课堂以“我”为本,最适应学生发展层次,最接近学生最近发展区,强调“师”的支持与服务,强调教与学的有机融合。

五、学法指导:

授人鱼,不如授人以渔,方法和能力的习得是有价值的教学的诉求。本课通过自主探索,小组讨论,协作交流等方式,引导学生在尝试、讨论、感悟、体验、合作、总结、拓展中多维互动,使学生成为自主建构的核心和学习活动的主体。使原本单调的学习过程演变成学生主动参与,充满乐趣、充满想象、不断创新的过程。

六、教学过程

“多维交互我课堂教学模式”引领下的课堂主要分为四大块:我准备、我探究、我提升、我检测

1、“我准备”

“我准备”就是预学,是学生个体建构新知的过程,是学生独立学习新知的一次“前检测”。课前,我通过布置、引导学生预学,明确学习目标,思索学习方法,使学生有准备地面对课堂,使课堂成为学生的内在需要。这也符合“高效课堂”对教学提出的要求。

2、“我检测”

“检测”就是搞“学情”调查。“我检测”是学生运用课堂学习的已有知识经验,自觉地对“自己的思维过程或结果进行检验、判断的`过程,也是自我调节、完善、发展认知结构的过程。

设计两个小练习:1是“正确的姿势”,2是“基准键”的认识。通过教师演示“不看键盘也能找准手指在键盘上的位置,一下子就激发了学生的学习兴趣。如此创设的激趣情境,不仅激发学生的学习兴趣,增加目标达成效果,也能沟通师生感情,促进愉快的教,愉快的学,乐教乐学,其乐无穷。

3、“我探究”

信息技术课堂的主体是“探究”。实施课堂探究,需通过“问题导引”,创设探究情境,引领和鼓励学生带着积极的情感进入“我要学”状态,自主参与、大胆探索、积极讨论、合作交流。学生学习方式是主动地学、互动地学、自我调控地学。

本环节设计一个打字游戏,继续保持学生的学习热情。随着游戏的进程,很多学生出现不能应付,自动放弃的情况,再加上教师的演示,从而突出矛盾,引起共鸣。“老师之所以能应付自如,也是有诀窍的,同学们想知道吗?”从而引导学生主动的参与学习。

4、“我实践”

信息技术课程不仅仅要学习各种知识和技能,更重要的是信息的处理方式和方法,学会用“计算机”的一些工作方式来思考和指导我们的操作。而这一目标,必须不断地通过实践才能逐步实现。在本节课中,教师精心设计教学情境和教学任务。充分利用“实践园”的课程资源,激发学生的实践兴趣。在这一环节,教师特别注重“我实践”的结果评价。对于学生完成的操作,教师都要正面、积极地评价。多表扬,少批评,多鼓励,少打击,让每一个层次水平的学生都体验到成功的快乐。

篇9:jQuery开发之DOM操作二

接上篇文章

3,插入节点

插入节点的方法如下图:

4,删除节点<?www.2cto.com/kf/ware/vc/” target=“_blank” class=“keylink”>vc3Ryb25nPiA8YnI+CigxKSByZW1vdmUoKbe9t6ggPGJyPgrX99PDyse000RPTdbQyb6z/cv509DGpcXktcTUqsvYoaPKvsD9tPrC68jnz8KjujwvcD4KCgoKPHByZSBjbGFzcz0=“brush:java;”>var $li =$(“ul li:eq(1)”).remove; //获取第二个

节点后,将它从网页中删除,

注意:当某个节点用remove()删除后,该节点包含的所有后代节点将同时被删除。这个方法的返回值是一个指向被删除节点的引用,因此可以在以后继续使用这些元素。

(2) detach()方法

detach() 和remove()方法一样,也是从DOM中去掉匹配的元素,但需要注意的是,这个方法不会把匹配的元素从jQuery对象中删除,因而可以在将来再使用这些匹配的元素。与remove()不同的是,所有绑定的事件,附加的数据都会保留下来。

示例代码如下:

var $li =$(“ul li:eq(1)”).detach(); //获取第二个节点后,将它从网页中删除。

(3) empty()方法

严格来说empty()方法并不是删除节点,而是清空节点,它能清空元素中的所有后代节点。

示例代码如下:

var $li = $(“ul li:eq(1)”).empty(); //获取第二个节点后,清空元素里的内容。

5,复制节点

css ajax

选择最喜欢的水果

苹果橘子菠萝

6,节点替换

如果要替换某个节点,jQuery提供了相应的方法,即replaceWith()和replaceAll();

replaceWith()方法的作用是将所有匹配的元素都替换成指定的HTML活着DOM元素。

示例代码如下:

jQuery test

选择最喜欢的水果

苹果橘子菠萝

运行结果如下:

replaceAll()方法的示例代码如下:

jQuery test

选择最喜欢的水果

苹果橘子菠萝

运行结果如下:

7,包裹节点

(1) wrap()方法

jQuery代码示例如下:

$(“strong”).wrap(“


”); //用

标签将元素包裹起来

运行结果如下:

something

(2) wrapAll()方法

该方法会将所有匹配的元素用一个元素来包裹,它不同于wrap()方法,wrap() 方法是将所有的元素进行包裹,

jQuery示例代码如下:

$(“strong”).wrapAll(“


”);

运行结果如下:

你最喜欢的水果你最不喜欢的水果

(3) wrapInner()方法

该方法将每一个匹配的元素的字内容包括(文本节点) 用其结构化的标记包裹起来。jQuery示例代码如下:

$(“strong”).wrapInner(“


”);

运行结果如下:

最喜欢的水果

篇10:PHP之文件目录基础操作

我们知道,临时声明的变量是保存在内存中的,即便是静态变量,在脚本运行完毕后也会被释放掉,so,想长久保存一个变量的内容,方法之一就是写到文件中,放到硬盘或服务器上,为此文件操作就必须很熟悉,

1.文件的属性信息获取

首先文件具有类型,在Linux下边,有block(块设备,如磁盘分区、CD-ROM)、char(以字符为输入的设备,如键盘、打印机)、dir(目录类型,目录也是文件的一种)、fifo(命名管道,解释是将信息从一个进程传到另一个进程)、file(普通的文件)、link(链接,类似win下边的快捷方式)、unknow(未知类型)7大类,在win下边,只有3类:file、dir和unknown。Linux渣表示一定要好好搞一下Linux-_-,人家完全是为Linux而生。

关于类型的获取有这么几个函数:filetype:获取类型; is_file:判断为是否是正常文件; is_link:判断是否是链接。

关于属性的获取有这么几个函数:

file_exists:判断文件或目录是否存在;

filesize:获取文件大小;

is_readable、is_writable、is_executable :是否可读、可写、可执行;

filectime、filemtime、fileatime:获取文件的创建时间(create)、修改时间(modify)、访问时间(access),均返回时间戳;

stat:获取文件的一些基本信息,返回一个索引与关联混合数组。

比如,可以这样判断文件类型:

复制代码

function getFileType($path){ // 获取文件类型

switch(filetype($path)){

case 'file': return 'ordinary file';

case 'dir': return 'directory';

case 'block': return 'block device file';

case 'char': return 'transfer device base on char';

case 'fifo': return 'named pipes';

case 'link': return 'symbol link';

default: return 'unknown type';

}

}

复制代码

filesize返回的是以字节为单位的数据,如果是大文件数字或很大,可以对数字先处理一下,代码如下

复制代码

// 处理文件大小

function getSize($path = '', $size = -1){

if($path !== null && $size == -1){  // 只传路径就计算大小,也可以使之只处理数字

$size = filesize($path);

}

if($size >= pow(2, 40)){

return round($size/pow(2, 40), 2).'TB';

}

else if($size >= pow(2, 30)){

return round($size/pow(2, 30), 2).'GB';

}

else if($size >= pow(2, 20)){

return round($size/pow(2, 20), 2).'MB';

}

else if($size >= pow(2, 10)){

return round($size/pow(2, 10), 2).'KB';

}

else{

return round($size, 2).'Byte';

}

}

复制代码

现在综合来获取一下文件信息,代码如下:

复制代码

function getFileInfo($path){

if(!file_exists($path)){  // 判断文件是否存在

echo 'file not exists!

';

return;

}

if(is_file($path)){  // 是文件,打印基础文件名

echo basename($path).' is a file

';

}

if(is_dir($path)){  // 是目录 ,返回目录

echo dirname($path).' is a directory

';

}

echo 'file type:'.getFileType($path).'

'; // 获取文件类型

echo 'file size:'.getSize($path).'

'; // 获取文件大小

if(is_readable($path)){ // 是否可读

echo basename($path).' is readable

';

}

if(is_writeable($path)){ // 是否可写

echo basename($path).' is writeable

';

}

if(is_executable($path)){ // 是否可执行

echo basename($path).' is executable

';

}

// touch函数可以修改这些时间

echo 'file create time: '.date('Y-m-d H:i:s', filectime($path)).'

'; // 创建时间

echo 'file modify time: '.date('Y-m-d H:i:s', filemtime($path)).'

'; // 修改时间

echo 'last access time: '.date('Y-m-d H:i:s', fileatime($path)).'

'; // 上次访问时间

echo 'file owner: '.fileowner($path).'

'; // 文件拥有者

echo 'file permission: '.substr(sprintf('%o', (fileperms($path))), -4).'

'; // 文件权限,八进制输出

echo 'file group: '.filegroup($path).'

'; // 文件所在的组

}

复制代码

效果如下:

代码中还用到了文件权限、所在组等函数,有必要解释下(说的不对请修正)。一个文件的权限分为可读可写可执行,一般这样表示:rwx,字母对应的表示可读可写可执行,从前往后规定值为4、2、1,三个值相加的结果最大为7,因此0666用的是八进制表示,这样看起来就很方便。为7则表示这个文件具备这三个权限,那为什么打印的是0666呢?我们都知道,进入windows下面是有一个用户的,在Linux下边,与windows类似,也是有一个用户登录进去,因此一个文件可能为该用户所有,一个用户它还有自己所在的组,以及该系统中还有其他组(猜想这样分应该是管理上的需要),因此对于0666,对于第一个6,表示该用户对该文件的权限,第二个6表示该用户所在的组对该文件的权限,第三个6表示其他的组所具有的权限(这样就不用一一去区分除本组外其他的用户了),6就知道该文件是可读可写的(win下可执行都知道是.exe文件)。

2.目录操作

目录的读取,opendir:打开一个目录,返回一个句柄,指向该目录中的内容,如果把目录中的内容看成一个有顺序的数据,比如按顺序的排列的数组,这个句柄就指向这个数组的开头,事实上,系统会把该目录中的内容按照字典排序,无论是文件还是子目录。readdir:读取下一个目录内容,返回文件名,并自动指向该目录中的下一个文件/目录,所以读取一个目录中的内容,不包括子目录中的内容,需要一个循环来控制,在读取完后,还要关闭句柄变量,C语言读取文件时也是这样,打开就有关闭。以我的机子举例:

复制代码

// 目录的读取

$dir = 'F:/';

echo 'details in '.$dir.'

';

if(is_dir($dir)){

if(($handle = opendir($dir)) == false){   // 获取目录句柄

echo 'open dir failed';

return;

}

while(($name = readdir($handle)) != false){ // 循环读取该目录下内容

$filepath = $dir.'/'.$name;

echo 'name: '.$name.' type: '.filetype($filepath).'

';

}

closedir($handle);             // 关闭目录句柄

}

else{

echo $dir.' is not a directory';

}

复制代码

效果如下:

可以看到实际上,系统给目录中内容进行了忽略大小写的字典排序。

目录的大小计算,我们知道文件的大小可以由filesize取得,但是php中没有专门计算目录大小的函数。当然php中有计算硬盘大小的函数disk_total_space(计算硬盘总空间)、disk_free_space(计算硬盘可用空间),但是我试了下disk_free_space,貌似计算得不对。正因为有filesize计算文件的大小,因此,需要用到递归,当是目录时,进去继续计算子目录的大小,如果是文件,获取到文件大小并加上返回,代码如下:

复制代码

// 目录大小计算

function getDirSize($dirpath){

$size = 0;

if(false != ($handle = opendir($dirpath))){

while(false != ($file = readdir($handle))){

if($file == '.' || $file == '..')    //注意过滤目录中自带的点和点点

continue;

$filepath = $dirpath.'/'.$file;     // 前面要接上路径

if(is_file($filepath)){         // 是文件计算大小

$size += filesize($filepath);

}

else if(is_dir($filepath)){       // 是目录继续计算该目录下的文件

$size += getDirSize($filepath);

}

else{

$size += 0;

}

}

closedir($handle);

}

return $size;

}

$dirsize = 'F:/size';

$size = getDirSize($dirsize);

echo 'dir size: '.getSize(null, $size).'

'; // 调用前面的数据处理函数

复制代码

我在F盘建了个size文件,随便弄了点子目录和文档,效果如下,左边是程序求得,右边是右键查看文件夹属性得到的,用以对比,

目录的新建和删除,主要用到,mkdir:新建一个目录,rmdir:删除一个非空目录,注意只能是非空,代码如下:

复制代码

// 目录的新建和删除

$newDirPath = 'F:/newDir';

if(true == @mkdir($newDirPath, 0777, true)){   // 加@是因为文件已存在时php本身可能会抛出一个warning

echo 'create directory '.$newDirPath.' successfully

';

}

else{

if(file_exists($newDirPath))

echo 'directory '.$newDirPath.' has existed

';

else

echo 'create directory '.$newDirPath.' failed

';

}

if(true == @rmdir('F:/aaa'))    //只能删除非空目录,如果删除不存在的目录自动抛出warning

echo 'remove successfully

';

复制代码

那么问题来了,如果要删除一个非空目录咋办,又得自己写了,思想仍然是递归,因为php只提供了删除文件函数unlink,所以在删除一个目录时,先opendir,再进入,如果是文件直接删除,如果是目录,继续进入使用该方法处理,当然还可已返回一个bool变量表示删除是否成功,代码如下:

复制代码

// 删除文件 unlink

// 删除目录中的内容,然后删除该目录

function clearDir($dirpath){

if(file_exists($dirpath)){

if(false != ($handle = opendir($dirpath))){

while(false != ($name = readdir($handle))){

if($name == '.' || $name == '..')

continue;

$filename = $dirpath.'/'.$name;

if(is_dir($filename))

clearDir($filename);

if(is_file($filename))

@unlink($filename);

}

closedir($handle);

rmdir($dirpath);

}

else{

return false;

}

}

else{

return false;

}

return true;

}

复制代码

在这里不得不说遇到的一个大坑,就是 . 和 .. 这两个鬼玩意儿(点和点点),在操作系统中的每一个文件夹下边,都会有 . 和 .. ,它们表示当前目录和当前目录的上级目录,可恶的是前面在读取目录时居然没显示,导致递归函数成了死循环,因为 . 和 .. 在每一个目录的最前面,必然会先读到它俩,若不过滤,首先读到 . ,它表示本目录,然后又递归进入本目录...这俩是操作系统下面的默认有的,它们是本目录与上级目录的连接符。

通过计算目录的大小和删除非空目录的代码,写复制和剪切目录就非常容易,非常相似的递归思想,需要用到复制文件函数copy,文件移动函数rename,这个挺有趣,rename,字面上是重命名,但是重命名到另一个目录中不就是剪切了么-_-

3.文件读写

php的某些文件读取操作跟C语言非常像,所以也比较简单,步骤就是先打开文件获取句柄,检查错误,然后读写处理,然后关闭,养成打开处理完后就关闭的好习惯,记得在C语言中的文件不关闭的话,打开两次是会报错滴,不知道记错没,所以严格点的程序都有非常多的处理,比如先验证文件存在,然后验证可读可写性,然后先关闭一下,然后再打开,打开时还得再检查打开错了没......在打开文件时,就要选择打开文件的模式,它决定了我们读还是写文件,当然是对需要这样操作的函数有用。

写文件,写文件函数只有fwrite、fputs、file_put_contents少数几个,其中fwrite与fputs效果一样,file_put_contents是一次性向文件写入一些内容,它就不需要指定打开模式,同时它也可以是附加或者覆盖现有文件内容,比如:

复制代码

// 写 fwrite(别名fputs)

$filepath = 'F:/10m.txt';

function writeSome($filepath){

if(($handle = fopen($filepath, 'r+')) == true){

for($i=0; $i<10; $i++)

fwrite($handle, $i.“ write something\r\n”); // windws以\r\n作为换行符

fclose($handle);

}

}

file_put_contents($filepath, 'use file_put_contents function', FILE_APPEND); // 附加内容

复制代码

读文件,读文件的函数多些,有fread(读取指定个字节)、fgetc(读取一个)、fgets(读取一行)、file(全部读取,按行分配到一个数组中返回)、file_get_contents(默认读取全部返回字符串)、readfile(直接将文件中内容输出到缓存,效果就是直接在浏览器上输出),伴随着fread、fget、fgets运行,文件指针会自动往后走。因此连续读最好是循环控制。读到文件末尾怎么办,EOF标识指示到达文件末尾,最好用feof检测是否到文件末尾。不多说,看代码:

复制代码

// fread读取

function readSome($filepath){

if(($handle = @fopen($filepath, 'r')) == true){

while(!feof($handle)){      // 判断是否到达文件末尾

$str = fread($handle, 10);  // fread读取时,文件指针自动向后移动

echo $str.'

';

}

}

}

复制代码

如果想要读取方式更灵活,就要配合fseek、rewind使用,它们可以移动文件指针到具体位置,fseek十分灵活,可以直接移到开头或末尾,或从当前位置往前或后移动,读取想要的内容,ftell还可告知当前位置,比如:

复制代码

function readFun($filepath){

if(($handle = @fopen($filepath, 'r')) != false){

echo 'current position: '.ftell($handle).'

'; // 输出文件当前文件指针位置,以字节算,0表示开头

$str = fread($handle, 3); // 读取3个字节,同时指针自动后移3个字节

echo 'read content: '.$str.'

';

echo 'current position: '.ftell($handle).'

';

fseek($handle, 5, SEEK_CUR); // 将文件指针从当前位置后移5个字节

echo 'current position: '.ftell($handle).'

';

$str = fread($handle, 5);

echo 'read content: '.$str.'

';

echo 'current position: '.ftell($handle).'

';

rewind($handle); // 返回文件开头

echo 'current position: '.ftell($handle).'

';

fseek($handle, 0, SEEK_END); // 移到文件末尾

echo 'current position: '.ftell($handle).'

';

fclose($handle); // 关闭文件

}

}

篇11:python基础教程之字典操作详解

最近更 新

在python的WEB框架Flask中使用多个配置文

python encode和decode的妙用

python解析发往本机的数据包示例 (解析数

python判断、获取一张图片主色调的2个实例

python之模拟鼠标键盘动作具体实现

python检测服务器是否正常

python 获取et和excel的版本号

Python 元类使用说明

python缩进区别分析

Python httplib,smtplib使用方法

热 点 排 行

Python入门教程 超详细1小时学会

python 中文乱码问题深入分析

比较详细Python正则表达式操作指

Python字符串的encode与decode研

Python open读写文件实现脚本

Python enumerate遍历数组示例应

Python 深入理解yield

Python+Django在windows下的开发

python 文件和路径操作函数小结

python 字符串split的用法分享

篇12:ERP操作技巧之发料成本

前几天,我跟公司一些新招的实施人员开了一个座谈会,请他们谈谈将近一年的顾问生涯的感受及遇到的阻碍,发现他们普遍对于成本计算不是很清楚,特别是发料成本相关的知识更是缺乏,这主要是因为他们以前都没有接触过财务相关的内容,对于成本的计算,更是第一次接触。

我发现他们主要是对于成本的相关知识没有形成一个体系,如对于发料成本,只知其一,不知其二。故,我在会后给他们总结了一份关于发料成本的资料,以供他们参考。

发料成本的计算,不同的企业有不同的要求,采用不同的方法。一般来说,发料成本的计算方法有先进先出法、后进先出法、加权平均法等等,其中,加权平均法又分为月加权平均法与移动加权平均法。现在,我就以具体的实例,来说明一下,各种计算方法的不同以及在ERP操作中的相关技巧。

一、先进先出法。

假如某个材料,在11月15日以5元的单价进了500件,在11月30日又以5.5元的价格进了400件。在12月1日,车间领走了700件。假设,该材料没有库存,就这两比进货。那仓库领走的这700件材料,成本到底算多少呢?算5元一件,还是5.5元一件,又或者是两者的平均值5.25元呢?

这主要看采取什么样的方法,来进行发料成本的核算。若企业采用先进先出法,则以上的成本都是错误的。先进先出法,顾名思义,就是先进来的材料先出去,后进来的材料后出去,成本价格按实际的价格来核算。如此时领了700件材料,前面500件按5元的价格核算,因为这500件是按5元的价格买进来的;剩余的200件是按5.5元的价格来核算的,即按照这后面购买的价格来算的。总共的材料成本为3600元。

注意事项:

1、这里我们所说的先进先出法,是帐目处理上的先进先出,跟实物没有什么关系。也就是说,帐目上根据先进先出法进行核算,但是,实务上,有可能是后来进的货先领出去。

2、若用先进先出法,则对于单据的及时审核要求更高。如若进货的时间相隔不是太久,只隔一天进货,当前一天的进货单没有及时审核时,推迟了一天审核,则在领料时,就在当天开领料单,则就会发生错误,因为领料单的成本价格无从考量。

3、在材料入库时,相关的费用要及时录入。有些公司,材料的送货费用已经包含在材料的价格中,但是,有些企业则不是。材料的采购价格跟材料的送货费用是分开的,但是,计算材料成本时,则要把两者加起来。所以,在入库时,若产生相关的费用,财务或者仓库要及时把费用单据入到系统中,并关联到对应的入库单中。这个单据的录入要及时,特别是不能够隔月处理,因为一般企业都是月底成本结转,否则,成本计算会不准。

二、后进先出法。

后进先出法,跟先进先出法类似,主要是企业出于谨慎的目的,发料的成本价格按最近的材料采购价格倒推。如在11月15日以5元的单价进了500件,在11月30日又以5.5元的价格进了400件。在12月1日,车间领走了700件。这700件的发料成本,若按照后进先出法,则其中400件是按照5.5元的价格来核算的,剩余的300件则是按照5元的价格来核算,最后,700件材料的总共材料成本为3700元。

注意事项:

后进先出法的计算方法,ERP的操作注意事项,跟先进先出法类似,一是要注意后进先出只是针对帐目,跟食物的发料顺序无关;二是相关的单据录入与审核要及时,特别是跟入库有关的费用单据,对于隔月入单子的现象,要严格避免。

三、月加权平均法。

加权平均方法比以上两种方法要复杂的多。因为其计算量大,所以在手工核算阶段,很少企业利用这种方式来进行发料成本的核算。加权平均法,根据需求精度的不同,又可以细分为两种情况,一是月加权平均法,二是移动加权平均成本法。

如11月初,某材料的库存材料成本为零,

11月5日以5元的单价进了500件,在11月10日又以5.5元的价格进了400件。在11月8日,车间领走了300件;在1月15日,车间又领走了400件。则这700件材料,该如何计算成本呢?

月加权平均成本的计算思路:

1、在领料时,ERP系统不会关系具体的材料成本数据。也就是说,利用月加权平均成本计算时,在领料时,只关心领料的数量。具体的材料成本,是在月底在计算的。

2、到月底时,会根据本月的进货数量与进货价格,加权平均,计算出当月材料的平均成本价格。如上例,按照加权平均,计算出来的平均单位材料成本价格为(500件*5元+400件*5.5元)/(500件+400件)=5.22元。即当月700件材料的总共成本为3654元。从这里可以看出,月加权平均成本跟其他成本计算方法有一个显著的区别,就是,在本月中发生的领料事件,其单位材料成本都是一致的。

3、仓库剩余的200件材料成本也是按照5.22元的价格计算,得出的材料成本,做为下个月月加权材料成本计算的基数。当每月进货次数比较多时,这个计算就比较麻烦。若靠手工核算的话,就会有一定的难度。

注意事项:

1、这种方法虽然对于单据,如原材料进货单、原材料发料单等的及时性没有很严格的要求,但是,其要求在月底成本结转前,必须把相关的单据都录入完毕。所以,用户在月底前,做这支作业时,要检查相关的单据有没有全部录入,录入的单据有没有及时审核,特别是价格变更的话,价格变更单有没有及时录入及审核。这些小失误,最终都会影响产品的材料成本的准确性。

2、月末库存盘点对于材料成本的影响。企业出于材料安全的原因,会定期、不定期的对仓库进行盘点。若盘点数量跟库存帐面数量不准时,会调整相关数据。这数据的调整会影响期初的材料成本。用户要特别关注,这个事件对于材料成本的影响。

四、移动加权平均法。

移动加权成本跟月加权成本虽然只有一字之差,但是,其复杂程度、精确度不可同日而语。

如11月初,某材料的库存材料成本为零。11月5日以5元的单价进了500件,在11月10日又以5.5元的价格进了400件。在11月8日,车间领走了300件;在11月15日,车间又领走了400件。

移动加权平均法的基本思路是,每次进货,都计算一次材料成本,跟这批进货的数量与价格调整相关的材料成本。

在11月5日进货时,因为没有期初库存,所以,按5元的价格计算材料成本,总共库存材料为2500元;单位材料成本为5元。

在11月10日领料时,就以11月5日的单位材料成本为基础,计算发料成本。11月5日总共领料300件,即领料成本为1500元,库存的材料成本为2500元-1500元=1000元。

11月10日进货时,在材料录库时,会进行一次加权平均的计算。即(1000+400*5.5)/(200+400)=5.33元。在11月15日领料时,就以5.33的单位成本价格进行发料,400件的发料成本为400*5.33=2132元。当月700件材料的成本总共为3632元。

ERP操作注意事项:

从以上的计算,我们可以看出,日加权平均成本对于单据的及时性要求很高。如11月10日的领料单,在当日没有及时审核的话,在11月11日再审核时,则成本价格就会不一样。所以,如采用日加权平均成本,我们要求用户每日的单据,在当天就要录入审核完毕,不要拖到下一天。

从这四个例子中,我们可以看出,四种方法计算的成本价格都不一样,但是,并不是说哪种方法准确,其他方法有错误。只是因为核算的方法不同而已。企业可以根据自己的熟悉程度或者精度要求,来进行选择。一般来说,加权平均成本比其他两种方法的精度要高,而日加权平均成本又比月加权平均成本要高。当然,随着精度的提高,对于管理水平的要求,也随之提高。

所以,用户要在两者之间进行判断,选择一个合适的的方法。不过要注意的是,一旦方法确定,在短时间内,就不要再做调整,核算方法的前后统一,不仅是会计管理制度上的要求,也是ERP对于成本核算上的要求。

篇13:Word编辑排版文档之操作快捷键

[F1]键:帮助

[F2]键:移动文字或图形,按回车键确认

[F4]键:重复上一次的操作

[F5]键:编辑时的定位

[F6]键:在文档和任务窗格或其他Word窗格之间切换

[F8]键:打开Word的选择模式

[F12]键:打开“另存为”对话框

[shift+F2]组合键:复制文本

[shift+F3]组合键:改变字母大小写

[shift+F4]组合键:重复查找或定位

[shift+F12]组合键:选择“文件”菜单中的“保存”菜单项

[shift+F5]组合键:跳转文档中上一次编辑位置

[shift+←] 组合键:选中光标左侧一个字符

[shift+→] 组合键:选中光标右侧一个字符

[shift+↑] 组合键:选中光标当前位置至上一行之间的内容

[shift+↓] 组合键:选中光标当前位置至下一行之间的内容

[shift+Ena] 组合键:选中光标所在处至行尾

[shift+Home] 组合键:选中光标所在处至行首

[shift+pageup] 组合键:选中光标当前位置至上一屏之间的一行内容

[Shift+Pagedown] 组合键:选中光标当前位置至下一屏之间的一行内容

[ctri+F2] 组合键:打印预览

[ctri+F4] 组合键:关闭窗口

[ctri+F6] 组合键:在打开的文档之间切换

[ctri+F12] 组合键:打开“打开”对话框

[ctri+1] 组合键:单倍行距

[ctri+2] 组合键:双倍行距

[ctri+5] 组合键:1.5倍行距

[ctri+O] 组合键:段前添加一行间距

[ctri+A] 组合键:全选

[ctri+B] 组合键:字符变为粗体

[ctri+C] 组合键:复制

[ctri+shift+D] 组合键:分散对齐

[ctri+E] 组合键:段落居中

[ctri+F] 组合键:查找

[ctri+G] 组合键:定位

[ctri+H] 组合键:替换

[ctri+I] 组合键:字符变为斜体

[ctri+J] 组合键:两端对齐

[ctri+K] 组合键:超级连接

[ctri+L] 组合键:左对齐

[ctri+N] 组合键:新建文档

[ctri+M] 组合键:左侧段落缩进

[ctri+O] 组合键:打开文档

[ctri+P] 组合键:打印

[ctri+Q] 组合键:插入点所在行向左移动一个字符

[ctri+Q] 组合键:取消段落格式

[ctri+R] 组合键:右对齐

[ctri+S] 组合键:保存

[ctri+T] 组合键:创建悬挂缩进

[ctri+U] 组合键:为字符添加下划线

[ctri+V] 组合键:粘贴

[ctri+W] 组合键:

[ctri+X] 组合键:剪贴

[ctri+Shift+Z] 组合键:格式清除

[ctri+ shift] 组合键:输入法转换

[ctri+F8] 组合键:打开“宏”的对话框

[ctri+空格] 组合键:中、西文转换

[ctri+Enter] 组合键:插入分页符

[ctri+ shift+M] 组合键:取消左侧段落缩进

[ctri+ shift+F12] 组合键:选择“文件”菜单中的“打印”菜单项

[ctri+ shift+F] 组合键:改变字体

[ctri+ shift+P] 组合键:改变字号

[ctri+ shift+>] 组合键:增大字号

[ctri+ shift<] 组合键:减小字号

[ctri+ shift+]] 组合键:逐磅增大字号

[ctri+ shift+[] 组合键:逐磅减小字号

[ctri+ shift+C] 组合键:复制格式

[ctri+ shift+V] 组合键:粘贴格式

[ctri+ shift+T] 组合键:减小悬挂缩进量

[ctri+ Enter] 组合键:插入分页符

[ctri+Home] 组合键:插入点移到文档首部

[ctri+End] 组合键:插入点移到文档尾部

[ctri+ shift+←] 组合键:将光标移到单词开始处

[ctri+ shift+→] 组合键:将光标移到单词结尾处

[ctri+ shift+↑] 组合键:将光标移到段首

[ctri+ shift+↓] 组合键:将光标移到段尾

[ctri+ shift+Home] 组合键:将光标移到文档开始处

[ctri+ shift+Ena]组合键:将光标移到文档结尾处

[ctri+PGVP] 组合键:将插入点移至上一页窗口顶部

[ctri+PGDW]组合键:将插入点移至下一页窗口顶部

[shift+Home]组合键:插入点到行首

[shift+Ena]组合键:插入点到行尾

[shift+空格]组合键:半角/全角切换

[Ctri+左键] 组合键:选中一段文字

[Ait+左键] 组合键:选中一块文字

[Ait+Ctri+ Shift+Pagedown]组合键:将光标移到窗口结尾

[Ait+Ctri+C] 组合键:插入版权符号

[Ait+Ctri+R]组合键:插入注册商标符号

[Ait+Ctri+T]组合键:插入商标符号

[Ait+Ctri+.]组合键:插入省略号

[Ait+Tab] 组合键:切换任务、窗口

[Ait+F4] 组合键:关闭程序

[Ait+空格] 组合键:下拉Word控制菜单

[Ait+Prntscreen] 组合键:窗口复制,

Word编辑排版文档之操作快捷键

按住[Ait]键,可以暂时忽略网格使图片平滑移动。

按住[Shift]键,依次选取需要对齐的图形,完成若干图形对齐任务。

按住[Shift]键并单击“打印预览”按扭,可快速打印工作表。

按[shift+Enter]组合键,可以在当前幻灯片的后面插入一张新幻灯片。

按[Tab]键,选择下一个单元格;

按[Shift+ Tab]组合键选择前一个单元格。

按[Shift]键,再按回车键,就会产生一个换行符。

如果打开的窗口或窗体角朵,并且把数据库窗口完全挡住了,这时只要按下[F11](也可以按下[Ait+ F11]),数据库窗口将被前置。

按[Ctri+:]组合键,可以输入当前日期;

按[Ctri+ shift+:] 组合键,可以输入当前时间。

选定大块区域,,按[Shift]键后拖动鼠标。

选定矩形区域,,按[Ait]键后拖动鼠标(大纲视图下无效)。

篇14:Redis基本数据类型操作之 list

Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API,从2010年3月15日起,Redis的开发工作由VMware主持。

list基本操作

Redis的list类型其实就是一个每个子元素都是string类型的双向链表。链表的最大长度是(2的32次方)。我们可以通过push,pop操作从链表的头部或者尾部添加删除元素。这使得list既可以用作栈,也可以用作队列。

有意思的是list的pop操作还有阻塞版本的,当我们[lr]pop一个list对象时,如果list是空,或者不存在,会立即返回nil。但是阻塞版本的b[lr]pop可以则可以阻塞,当然可以加超时时间,超时后也会返回nil。为什么要阻塞版本的pop呢,主要是为了避免轮询。举个简单的例子如果我们用list来实现一个工作队列。执行任务的thread可以调用阻塞版本的pop去获取任务这样就可以避免轮询去检查是否有任务存在。当任务来时候工作线程可以立即返回,也可以避免轮询带来的延迟。

1、lpush

在key对应list的头部添加字符串元素:

redis 127.0.0.1:6379> lpush mylist “world”(integer) 1redis 127.0.0.1:6379> lpush mylist “hello”(integer) 2redis 127.0.0.1:6379> lrange mylist 0 -11) “hello”2) “world”redis 127.0.0.1:6379>

在此处我们先插入了一个world,然后在world的头部插入了一个hello。其中lrange是用于取mylist的内容。

2、rpush

在key对应list的尾部添加字符串元素:

redis 127.0.0.1:6379> rpush mylist2 “hello”(integer) 1redis 127.0.0.1:6379> rpush mylist2 “world”(integer) 2redis 127.0.0.1:6379> lrange mylist2 0 -11) “hello”2) “world”redis 127.0.0.1:6379>

在此处我们先插入了一个hello,然后在hello的尾部插入了一个world。

3、linsert

在key对应list的特定位置之前或之后添加字符串元素:

redis 127.0.0.1:6379> rpush mylist3 “hello”(integer) 1redis 127.0.0.1:6379> rpush mylist3 “world”(integer) 2redis 127.0.0.1:6379> linsert mylist3 before “world” “there”(integer) 3redis 127.0.0.1:6379> lrange mylist3 0 -11) “hello”2) “there”3) “world”redis 127.0.0.1:6379>

在此处我们先插入了一个hello,然后在hello的尾部插入了一个world,然后又在world的前面插入了there。

4、lset

设置list中指定下标的元素值(下标从0开始):

redis 127.0.0.1:6379> rpush mylist4 “one”(integer) 1redis 127.0.0.1:6379> rpush mylist4 “two”(integer) 2redis 127.0.0.1:6379> rpush mylist4 “three”(integer) 3redis 127.0.0.1:6379> lset mylist4 0 “four”OKredis 127.0.0.1:6379> lset mylist4 -2 “five”OKredis 127.0.0.1:6379> lrange mylist4 0 -11) “four”2) “five”3) “three”redis 127.0.0.1:6379>

在此处我们依次插入了one,two,three,然后将标是0的值设置为four,再将下标是-2的值设置为five。

5、lrem

从key对应list中删除count个和value相同的元素。

count>0时,按从头到尾的顺序删除,具体如下:

redis 127.0.0.1:6379> rpush mylist5 “hello”(integer) 1redis 127.0.0.1:6379> rpush mylist5 “hello”(integer) 2redis 127.0.0.1:6379> rpush mylist5 “foo”(integer) 3redis 127.0.0.1:6379> rpush mylist5 “hello”(integer) 4redis 127.0.0.1:6379> lrem mylist5 2 “hello”(integer) 2redis 127.0.0.1:6379> lrange mylist5 0 -11) “foo”2) “hello”redis 127.0.0.1:6379>

count<0时,按从尾到头的顺序删除,具体如下:

redis 127.0.0.1:6379> rpush mylist6 “hello”(integer) 1redis 127.0.0.1:6379> rpush mylist6 “hello”(integer) 2redis 127.0.0.1:6379> rpush mylist6 “foo”(integer) 3redis 127.0.0.1:6379> rpush mylist6 “hello”(integer) 4redis 127.0.0.1:6379> lrem mylist6 -2 “hello”(integer) 2redis 127.0.0.1:6379> lrange mylist6 0 -11) “hello”2) “foo”redis 127.0.0.1:6379>

count=0时,删除全部,具体如下:

redis 127.0.0.1:6379> rpush mylist7 “hello”(integer) 1redis 127.0.0.1:6379> rpush mylist7 “hello”(integer) 2redis 127.0.0.1:6379> rpush mylist7 “foo”(integer) 3redis 127.0.0.1:6379> rpush mylist7 “hello”(integer) 4redis 127.0.0.1:6379> lrem mylist7 0 “hello”(integer) 3redis 127.0.0.1:6379> lrange mylist7 0 -11) “foo”redis 127.0.0.1:6379>

6、ltrim

保留指定key 的值范围内的数据:

redis 127.0.0.1:6379> rpush mylist8 “one”(integer) 1redis 127.0.0.1:6379> rpush mylist8 “two”(integer) 2redis 127.0.0.1:6379> rpush mylist8 “three”(integer) 3redis 127.0.0.1:6379> rpush mylist8 “four”(integer) 4redis 127.0.0.1:6379> ltrim mylist8 1 -1OKredis 127.0.0.1:6379> lrange mylist8 0 -11) “two”2) “three”3) “four”redis 127.0.0.1:6379>

7、lpop

从list的头部删除元素,并返回删除元素:

edis 127.0.0.1:6379> lrange mylist 0 -11) “hello”2) “world”redis 127.0.0.1:6379> lpop mylist“hello”redis 127.0.0.1:6379> lrange mylist 0 -11) “world”redis 127.0.0.1:6379>

8、rpop

从list的尾部删除元素,并返回删除元素:

redis 127.0.0.1:6379> lrange mylist2 0 -11) “hello”2) “world”redis 127.0.0.1:6379> rpop mylist2“world”redis 127.0.0.1:6379> lrange mylist2 0 -11) “hello”redis 127.0.0.1:6379>

9、rpoplpush

从第一个list的尾部移除元素并添加到第二个list的头部,最后返回被移除的元素值,整个操作是原子的.如果第一个list是空或者不存在返回nil:

redis 127.0.0.1:6379> lrange mylist5 0 -11) “three”2) “foo”3) “hello”redis 127.0.0.1:6379> lrange mylist6 0 -11) “hello”2) “foo”redis 127.0.0.1:6379> rpoplpush mylist5 mylist6“hello”redis 127.0.0.1:6379> lrange mylist5 0 -11) “three”2) “foo”redis 127.0.0.1:6379> lrange mylist6 0 -11) “hello”2) “hello”3) “foo”redis 127.0.0.1:6379>

10、lindex

返回名称为key的list中index位置的元素:

redis 127.0.0.1:6379> lrange mylist5 0 -11) “three”2) “foo”redis 127.0.0.1:6379> lindex mylist5 0“three”redis 127.0.0.1:6379> lindex mylist5 1“foo”redis 127.0.0.1:6379>

11、llen

返回key对应list的长度:

redis 127.0.0.1:6379> llen mylist5(integer) 2redis 127.0.0.1:6379>

特殊功能的车说课稿

教你简单制作雪花

用软盘装大文件应用技巧四则

Win XP/系统服务备份与保护

如何让电脑免遭网络病毒的危害?

销售四月工作计划

会变魔法的小老鼠作文

文秘专业知识内容

IOS LPD远程缓冲区溢出漏洞

公司文件打印制度

WinZip解压缩之操作教学
《WinZip解压缩之操作教学.doc》
将本文的Word文档下载到电脑,方便收藏和打印
推荐度:
点击下载文档

【WinZip解压缩之操作教学(精选14篇)】相关文章:

个人电脑日常维护2023-03-25

个人电脑的基本维护常识2023-08-19

个人电脑日常维护22022-08-28

会变味道的魔法苹果作文2022-11-01

网站测试,Web性能测试与可用性测试2023-05-25

瑞星防火墙使用心得2023-06-19

大班四月工作计划2023-12-14

备份与恢复Win的AD数据库Windows系统2022-04-30

如何降低WPS文档占用空间2022-05-07

Discuz论坛宣传与优化技巧概述2022-06-22

点击下载本文文档