澳门新萄京8522七个Map的对照,二种办法,将相比较结果写入文件。

澳门新萄京8522七个Map的对照,二种办法,将相比较结果写入文件。

 

一、SequenceFile

SequenceFile的蕴藏类似于Log文件,所差别的是Log
File的每条记下的是纯文本数据,而SequenceFile的每条记下是可种类化的字符数组。

SequenceFile可因而如下API来实现新记录的增加操作:

       
fileWriter.append(key,value)

能够见到,每条记下以键值对的诀要开始展览组织,但前提是Key和Value需具备种类化和反连串化的效果

Hadoop预约义了部分Key Class和Value
Class,他们径直或直接完结了Writable接口,满意了该功效,包含:

Text                                等同于Java中的String
IntWritable                   等同于Java中的Int
BooleanWritable        等同于Java中的Boolean
        .
        .

在仓库储存结构上,SequenceFile首要由3个Header后跟多条Record组成,如图所示:

澳门新萄京8522 1

Header首要蕴涵了Key classname,Value
classname,存款和储蓄压缩算法,用户自定义元数据等音讯,别的,还蕴藏了有个别1并标识,用于飞快稳定到记录的边界。

每条Record以键值对的主意开始展览仓库储存,用来表示它的字符数组可依次解析成:记录的长度、Key的长度、Key值和Value值,并且Value值的结构取决于该记录是还是不是被核减。

数据压缩有利于节省磁盘空间和增长速度网络传输,SeqeunceFile扶助三种格式的数据压缩,分别是:record
compression和block compression。

record compression如上海教室所示,是对每条记下的value进行削减

block
compression是将一体系的record协会到壹块儿,统一压缩成二个block,如图所示:

澳门新萄京8522 2

block消息根本囤积了:块所含有的记录数、每条记下Key长度的集聚、每条记下Key值的集聚、每条记下Value长度的汇集和每条记下Value值的聚集

注:各样block的轻重缓急是可由此io.seqfile.compress.blocksize属性来钦定的

示例:SequenceFile读/写 操作

[java] view
plaincopy

  1. Configuration conf=new Configuration();  
  2. FileSystem fs=FileSystem.get(conf);  
  3. Path seqFile=new Path(“seqFile.seq”);  
  4. //里德r内部类用于文书的读取操作  
  5. SequenceFile.Reader reader=new SequenceFile.Reader(fs,seqFile,conf);  
  6. //Writer内部类用于文书的写操作,要是Key和Value都为Text类型  
  7. SequenceFile.Writer writer=new SequenceFile.Writer(fs,conf,seqFile,Text.class,Text.class);  
  8. //通过writer向文书档案中写入记录  
  9. writer.append(new Text(“key”),new Text(“value”));  
  10. IOUtils.closeStream(writer);//关闭write流  
  11. //通过reader从文书档案中读取记录  
  12. Text key=new Text();  
  13. Text value=new Text();  
  14. while(reader.next(key,value)){  
  15.     System.out.println(key);  
  16.     System.out.println(value);  
  17. }  
  18. IOUtils.closeStream(reader);//关闭read流  
public static void main(String[] args) {
    Map<String, Integer> map = new HashMap<>();
    map.put("孙悟空", 1);
    map.put("唐三藏", 2);
    map.put("猪八戒", 3);
    map.put("沙悟净", 4);

    Set<String> keySet = map.keySet();
    for (String key : keySet) {
        Integer value = map.get(key);
        System.out.println("键:"+ key + "值:"+ value);
    }

    Set<Entry<String, Integer>> set = map.entrySet();
    for (Entry<String, Integer> entry : set) {
        String key = entry.getKey();
        Integer value = entry.getValue();
        System.out.println("键:"+ key + "值"+value);
    }
    Iterator<Entry<String, Integer>> entrySet = map.entrySet().iterator();
    while (entrySet.hasNext()) {
        Entry<String, Integer> entry = entrySet.next();
        String key = entry.getKey();
        Integer value = entry.getValue();
        System.out.println("键:" + key + " " + "值:" + value);
    }
}

结果如下:

结果写入文件方式write

// 第二种格局遍历list集合:for循环
Integer size = list.size();
for (int i = 0; i < size; i++) {
String value1 = list.get(i);
System.out.println(value1);
}
// 第三种办法遍历list集合:iterator 迭代器
Iterator<String> iterator = list.iterator();
while (iterator.hasNext()) {
String value2 = iterator.next();
System.out.println(value2);
}
// 第一种方式遍历list集合:foreach
for (String string : list) {
System.out.println(string);
}

   
 Python的字典能够由此键获取其所对应的值,而种类型数据字符串,列表则是通过index索引来获取的。字典的成分的关联比较松散,是冬辰的。

   public static void write(String file, String valueOfMap1, String valueOfMap2) {

        try {
            BufferedWriter input = new BufferedWriter(new OutputStreamWriter(
                    new FileOutputStream(file, true)));
            input.write("Map1Output: " + valueOfMap1 + "\r\n");
            input.write("Map2Output: " + valueOfmap2 + "\r\n");
            input.newLine();
            input.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

Hadoop的HDFS和MapReduce子框架重如果针对大数据文件来计划的,在小文件的处理上不仅效能低下,而且10分消耗内部存款和储蓄器财富(每二个小文件占用1个Block,每3个block的元数据都存款和储蓄在namenode的内部存款和储蓄器里)。消除办法日常是挑选二个容器,将那些小文件组织起来统一存款和储蓄。HDFS提供了两连串型的器皿,分别是SequenceFile和MapFile。

// map遍历操作的第三种情势:map.entrySet() +迭代器
Iterator<Entry<String, Integer>> entrySet =
map.entrySet().iterator();
while (entrySet.hasNext()) {
Entry<String, Integer> entry = entrySet.next();
String key = entry.getKey();
Integer value = entry.getValue();
System.out.println(“键:” + key + ” ” + “值:” + value);
}
}
有着的方法都是卸载main方法之中的。

     判断某键是还是不是存在于字典里。

public class CompareMap {

    public static void main(String[] args) {

    }

    private void compare(Map<String, String> map1, Map<String, String> map2) {

        for (String testkey : map1.keySet()) {

            if(map1.get(testkey).equals(map2.get(testkey))){

                System.out.println("equals");

            }else{

                System.out.println("not equals");

            }
        }

    }

二、MapFile

MapFile是排序后的SequenceFile,通过观看其目录结构能够看来MapFile由两部分组成,分别是data和index。

index作为文件的数额索引,首要记录了各样Record的key值,以及该Record在文件中的偏移地方。在MapFile被访问的时候,索引文件会被加载到内部存款和储蓄器,通过索引映射关系可高效定位到钦点Record所在文书地点,由此,相对SequenceFile而言,MapFile的探寻效用是神速的,缺点是会损耗一部分内部存款和储蓄器来存款和储蓄index数据。

需注意的是,MapFile并不会把全数Record都记录到index中去,暗中同意意况下每隔12八条记下存款和储蓄2个索引映射。当然,记录间隔可人为修改,通过MapFIle.Writer的setIndexInterval()方法,或涂改io.map.index.interval属性;

其余,与SequenceFile分化的是,MapFile的KeyClass一定要兑现WritableComparable接口,即Key值是可正如的。

示范:MapFile读写操作

[java] view
plaincopy

  1. Configuration conf=new Configuration();  
  2. FileSystem fs=FileSystem.get(conf);  
  3. Path mapFile=new Path(“mapFile.map”);  
  4. //Reader内部类用于文书的读取操作  
  5. MapFile.Reader reader=new MapFile.Reader(fs,mapFile.toString(),conf);  
  6. //Writer内部类用于文书的写操作,即使Key和Value都为Text类型  
  7. MapFile.Writer writer=new MapFile.Writer(conf,fs,mapFile.toString(),Text.class,Text.class);  
  8. //通过writer向文档中写入记录  
  9. writer.append(new Text(“key”),new Text(“value”));  
  10. IOUtils.closeStream(writer);//关闭write流  
  11. //通过reader从文书档案中读取记录  
  12. Text key=new Text();  
  13. Text value=new Text();  
  14. while(reader.next(key,value)){  
  15.     System.out.println(key);  
  16.     System.out.println(key);  
  17. }  
  18. IOUtils.closeStream(reader);//关闭read流  

瞩目:使用MapFile或SequenceFile即便可以缓解HDFS中型小型文件的仓库储存难题,但也有一定局限性,如:
壹.文件不帮忙复写操作,不可能向已存在的SequenceFile(MapFile)追加存款和储蓄记录
二.当write流不关门的时候,未有艺术构造read流。也等于在实践文书写操作的时候,该文件是不可读取的

// map遍历操作的第二种方法:map.entrySet();+foreach 方法举办遍历
Set<Entry<String, Integer>> set = map.entrySet();
for (Entry<String, Integer> entry : set) {
String key = entry.getKey();
Integer value = entry.getValue();
System.out.println(“键:”+ key + “值”+value);
}

   
len函数能够测得字典的数量项个数。

 

public static void main(String[] args) {
    List<String> list = new ArrayList<>();
    list.add("孙悟空");
    list.add("唐三藏");
    list.add("猪八戒");
    list.add("沙悟净");
    String listString = list.toString();
    System.out.println(listString);

    Integer size = list.size();
    for (int i = 0; i < size; i++) {
        String value1 = list.get(i);
        System.out.println(value1);
    }
    System.out.println("==========================");

    Iterator<String> iterator = list.iterator();
    while (iterator.hasNext()) {
        String value2 = iterator.next();
        System.out.println(value2);
    }
    System.out.println("==========================");


    for (String string : list) {
        System.out.println(string);
    }
}}

澳门新萄京8522 3澳门新萄京8522 4

##其次种用keyset的法子,遍历Key值

// map遍历操作的第1种方法:keyset + foreach
// 选用keyset方法通过key值获取value值—》效用低
Set<String> keySet = map.keySet();
for (String key : keySet) {
Integer value = map.get(key);
System.out.println(“键:”+ key + “值:”+ value);
}

2,写文件

private void compareMap(Map<String, String> Map01, Map<String, String Map02>){  

     Iterator<String> iter = Map1.keySet().iterator();

while (iter.hasNext()) {

            String testKey = iter.next();

       if(Map1.get(testId).equals(Map2.get(testId))){

                System.out.println("equals");

              }else{

                System.out.println("not equals");

            }

Map的两种遍历格局:

1  >>> dict1['a']='hello'
2 >>> print dict1
3 {'a': 'hello', 12: 34, 'name': 'jeap'}

PS:假设须要将结果(相同的value、不一样的value)写入文件,则足以写二个write方法,在每一回打字与印刷写入文件,加文件地方参数即可

List的三种遍历方式:
public class TestList {

澳门新萄京8522 5澳门新萄京8522 6

在main方法调用并传递参就能够了,

   
 文件的readlines函数能够将文件文件的几何行文本1壹映射成列表的若干项,即文本文件的每1行映射成列表的3个数额项,每种数据项都以字符串。

 

三)成分值的修改:

#第贰种用entry

1 fr=open('templist.txt','r')
2 print fr.readlines()
3 fr.close()

两种办法的考虑都以遍历1个map的Key,然后三个Map分别取那2个Key值所收获的Value。

二,读成列表

private void compareMap(Map<String, String> Map01, Map<String, String Map02>){

        for (Map.Entry<String, String> entry : Map1.entrySet())
        {

           String testKey = entry.getKey();

           if(Map1.get(testId).equals(Map2.get(testId))){

                System.out.println("equals");

            }else{

                System.out.println("not equals");

            }
        }
}

View Code

#第三种用keyset的章程,把key值存到容器,分别取出比较

1 fr=open('templist.txt','r')
2 print fr.readline().strip().strip('\n')
3 print fr.readline().strip().strip('\n')
4 print fr.readline().strip().strip('\n')
5 fr.close() 

View Code

澳门新萄京8522 7澳门新萄京8522 8

View Code

View Code

陆)intems函数:获取字典全数的key-value。

View Code

十)实践应用:字典和for循环遍历字典。

澳门新萄京8522 9澳门新萄京8522 10

澳门新萄京8522 11澳门新萄京8522 12

3,读成1行文件

1 >>> dict1={'a': 'hello', 'QQ': '649414754', 'name': 'jeap', 'sex': 'F'}
2 >>> dict2=dict1.copy()
3 >>> print dict2
4 {'a': 'hello', 'QQ': '649414754', 'name': 'jeap', 'sex': 'F'}

一,格式化写文件

1 >>>
2 [' aaaaaaaa\n', ' bbbbbbbb\n', ' cccccccc']

五)成分项的加码:

澳门新萄京8522 13澳门新萄京8522 14

 1 >>> val=['Tom','Jack','Rose','John','Mark']
 2 >>> key=range(1,6)
 3 >>> dic=dict(zip(key,val))
 4 >>> print dic
 5 {1: 'Tom', 2: 'Jack', 3: 'Rose', 4: 'John', 5: 'Mark'}
 6 >>> dic.pop(2)
 7 'Jack'
 8 >>> dic.popitem()
 9 (1, 'Tom')
10 >>> print dic
11 {3: 'Rose', 4: 'John', 5: 'Mark'}

   
 只需点名文件时描述好路子即可,不过注意两点:一)转义字符的题材;2)无法成立文件夹,文件夹必须事先存在。

二)成分值的造访:

澳门新萄京8522 15澳门新萄京8522 16

View Code

View Code

Python学习类别(5)(文件操作及其字典)

澳门新萄京8522 17澳门新萄京8522 18

   
 假使想将壹些内容写入文件,能够以’w’写的情势打开文件(借使文件不存在会创建),并且清空文件以前的内容。

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图