最新服务器上的版本,以后用这个
wangzhenxin
2023-11-19 bc164b8bdbfbdf1d8229a5ced6b08d7cb8db7361
commit | author | age
2207d6 1 # PHPExcel Developer Documentation
W 2
3
4 ## Configuration Settings
5
6 Once you have included the PHPExcel files in your script, but before instantiating a PHPExcel object or loading a workbook file, there are a number of configuration options that can be set which will affect the subsequent behaviour of the script.
7
8 ### Cell Caching
9
10 PHPExcel uses an average of about 1k/cell in your worksheets, so large workbooks can quickly use up available memory. Cell caching provides a mechanism that allows PHPExcel to maintain the cell objects in a smaller size of memory, on disk, or in APC, memcache or Wincache, rather than in PHP memory. This allows you to reduce the memory usage for large workbooks, although at a cost of speed to access cell data.
11
12 By default, PHPExcel still holds all cell objects in memory, but you can specify alternatives. To enable cell caching, you must call the PHPExcel_Settings::setCacheStorageMethod() method, passing in the caching method that you wish to use.
13
14 ```php
15 $cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_in_memory;
16
17 PHPExcel_Settings::setCacheStorageMethod($cacheMethod);
18 ```
19
20 setCacheStorageMethod() will return a boolean true on success, false on failure (for example if trying to cache to APC when APC is not enabled).
21
22 A separate cache is maintained for each individual worksheet, and is automatically created when the worksheet is instantiated based on the caching method and settings that you have configured. You cannot change the configuration settings once you have started to read a workbook, or have created your first worksheet.
23
24 Currently, the following caching methods are available.
25
26 #### PHPExcel_CachedObjectStorageFactory::cache_in_memory
27
28 The default. If you don't initialise any caching method, then this is the method that PHPExcel will use. Cell objects are maintained in PHP memory as at present.
29
30 #### PHPExcel_CachedObjectStorageFactory::cache_in_memory_serialized
31
32 Using this caching method, cells are held in PHP memory as an array of serialized objects, which reduces the memory footprint with minimal performance overhead.
33
34 #### PHPExcel_CachedObjectStorageFactory::cache_in_memory_gzip
35
36 Like cache_in_memory_serialized, this method holds cells in PHP memory as an array of serialized objects, but gzipped to reduce the memory usage still further, although access to read or write a cell is slightly slower.
37
38 #### PHPExcel_CachedObjectStorageFactory::cache_igbinary
39
40 Uses PHPs igbinary extension (if its available) to serialize cell objects in memory. This is normally faster and uses less memory than standard PHP serialization, but isnt available in most hosting environments.
41
42 #### PHPExcel_CachedObjectStorageFactory::cache_to_discISAM
43
44 When using cache_to_discISAM all cells are held in a temporary disk file, with only an index to their location in that file maintained in PHP memory. This is slower than any of the cache_in_memory methods, but significantly reduces the memory footprint. By default, PHPExcel will use PHP's temp directory for the cache file, but you can specify a different directory when initialising cache_to_discISAM.
45
46 ```php
47 $cacheMethod = PHPExcel_CachedObjectStorageFactory:: cache_to_discISAM;
48 $cacheSettings = array( 
49     'dir' => '/usr/local/tmp'
50 );
51 PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);
52 ```
53
54 The temporary disk file is automatically deleted when your script terminates.
55
56 #### PHPExcel_CachedObjectStorageFactory::cache_to_phpTemp
57
58 Like cache_to_discISAM, when using cache_to_phpTemp all cells are held in the php://temp I/O stream, with only an index to their location maintained in PHP memory. In PHP, the php://memory wrapper stores data in the memory: php://temp behaves similarly, but uses a temporary file for storing the data when a certain memory limit is reached. The default is 1 MB, but you can change this when initialising cache_to_phpTemp.
59
60 ```php
61 $cacheMethod = PHPExcel_CachedObjectStorageFactory:: cache_to_phpTemp;
62 $cacheSettings = array( 
63     'memoryCacheSize' => '8MB'
64 );
65 PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);
66 ```
67
68 The php://temp file is automatically deleted when your script terminates.
69
70 #### PHPExcel_CachedObjectStorageFactory::cache_to_apc
71
72 When using cache_to_apc, cell objects are maintained in APC with only an index maintained in PHP memory to identify that the cell exists. By default, an APC cache timeout of 600 seconds is used, which should be enough for most applications: although it is possible to change this when initialising cache_to_APC.
73
74 ```php
75 $cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_to_APC;
76 $cacheSettings = array( 
77     'cacheTime' => 600
78 );
79 PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);
80 ```
81
82 When your script terminates all entries will be cleared from APC, regardless of the cacheTime value, so it cannot be used for persistent storage using this mechanism.
83
84 #### PHPExcel_CachedObjectStorageFactory::cache_to_memcache
85
86 When using cache_to_memcache, cell objects are maintained in memcache with only an index maintained in PHP memory to identify that the cell exists.
87
88 By default, PHPExcel looks for a memcache server on localhost at port 11211. It also sets a memcache timeout limit of 600 seconds. If you are running memcache on a different server or port, then you can change these defaults when you initialise cache_to_memcache:
89
90 ```php
91 $cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_to_memcache;
92 $cacheSettings = array( 
93     'memcacheServer' => 'localhost',
94     'memcachePort'   => 11211,
95     'cacheTime'      => 600
96 );
97 PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);
98 ```
99
100 When your script terminates all entries will be cleared from memcache, regardless of the cacheTime value, so it cannot be used for persistent storage using this mechanism.
101
102 #### PHPExcel_CachedObjectStorageFactory::cache_to_wincache
103
104 When using cache_to_wincache, cell objects are maintained in Wincache with only an index maintained in PHP memory to identify that the cell exists. By default, a Wincache cache timeout of 600 seconds is used, which should be enough for most applications: although it is possible to change this when initialising cache_to_wincache.
105
106 ```php
107 $cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_to_wincache;
108 $cacheSettings = array( 
109     'cacheTime' => 600
110 );
111 PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);
112 ```
113
114 When your script terminates all entries will be cleared from Wincache, regardless of the cacheTime value, so it cannot be used for persistent storage using this mechanism.
115
116 #### PHPExcel_CachedObjectStorageFactory::cache_to_sqlite
117
118 Uses an SQLite 2 "in-memory" database for caching cell data. Unlike other caching methods, neither cells nor an index are held in PHP memory - an indexed database table makes it unnecessary to hold any index in PHP memory, which makes this the most memory-efficient of the cell caching methods.
119
120 #### PHPExcel_CachedObjectStorageFactory::cache_to_sqlite3;
121
122 Uses an SQLite 3 "in-memory" database for caching cell data. Unlike other caching methods, neither cells nor an index are held in PHP memory - an indexed database table makes it unnecessary to hold any index in PHP memory, which makes this the most memory-efficient of the cell caching methods.
123
124
125 ### Language/Locale
126
127 Some localisation elements have been included in PHPExcel. You can set a locale by changing the settings. To set the locale to Brazilian Portuguese you would use:
128
129 ```php
130 $locale = 'pt_br';
131 $validLocale = PHPExcel_Settings::setLocale($locale);
132 if (!$validLocale) {
133     echo 'Unable to set locale to ' . $locale . " - reverting to en_us" . PHP_EOL;
134 }
135 ```
136
137 If Brazilian Portuguese language files aren't available, then Portuguese will be enabled instead: if Portuguese language files aren't available, then the setLocale() method will return an error, and American English (en_us) settings will be used throughout.
138
139 More details of the features available once a locale has been set, including a list of the languages and locales currently supported, can be found in the section of this document entitled "Locale Settings for Formulae".
140